整體結(jié)構(gòu)
成都創(chuàng)新互聯(lián)是一家專業(yè)從事成都做網(wǎng)站、成都網(wǎng)站建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司。作為專業(yè)網(wǎng)站制作公司,成都創(chuàng)新互聯(lián)依托的技術(shù)實(shí)力、以及多年的網(wǎng)站運(yùn)營(yíng)經(jīng)驗(yàn),為您提供專業(yè)的成都網(wǎng)站建設(shè)、成都全網(wǎng)營(yíng)銷推廣及網(wǎng)站設(shè)計(jì)開發(fā)服務(wù)!
【頁(yè)面頭部】
1、文件應(yīng)以“!DOCTYPE ......”首行頂格開始,推薦使用“!DOCTYPE html”
!DOCTYPE html
2、必須聲明文檔的編碼charset,且與文件本身編碼保持一致,指定字符編碼的?meta?必須是?head?的第一個(gè)直接子元素。推薦使用UTF-8編碼meta charset="utf-8"
(1)網(wǎng)頁(yè)顯示字符集
(2)可選標(biāo)簽
公司的版權(quán)注釋
網(wǎng)頁(yè)制作者信息
網(wǎng)站簡(jiǎn)介
設(shè)定網(wǎng)頁(yè)的到期時(shí)間,一旦網(wǎng)頁(yè)過期,必須到服務(wù)器上重新調(diào)閱
禁止瀏覽器從本地機(jī)緩存中調(diào)閱內(nèi)容
用來防止別人在框架中調(diào)用你的頁(yè)面
自動(dòng)跳轉(zhuǎn)
網(wǎng)頁(yè)搜索機(jī)器人向?qū)?,用來告訴機(jī)器人哪些頁(yè)面需要搜索,哪些頁(yè) 面不需要搜索
收藏夾圖標(biāo)
3、根據(jù)頁(yè)面內(nèi)容和需求填寫適當(dāng)?shù)膋eywords和description
4、頁(yè)面title是不可缺少的一項(xiàng),title?必須作為?head?的直接子元素,并緊隨?charset?聲明之后
[img]向大家介紹這些應(yīng)該遵循的Web前端開發(fā)原則。
1、善用DIV來布局
當(dāng)開發(fā)一個(gè)Web頁(yè)面時(shí),要考慮第一件事就是區(qū)分頁(yè)面重點(diǎn)。將這些內(nèi)容用DIV標(biāo)簽包含起來,頁(yè)面的代碼會(huì)呈現(xiàn)出整潔、縮進(jìn)良好的風(fēng)格。
2、將HTML標(biāo)簽和CSS樣式表分割開來
好的頁(yè)面應(yīng)該將HTML標(biāo)簽和CSS樣式表分割開來。這是每一個(gè)Web開發(fā)者在首次接觸Web開發(fā)時(shí)就應(yīng)該知道的一條原則。然而,直到今天,仍然有很多開發(fā)者沒有嚴(yán)格遵循這一原則。
不要在HTML標(biāo)簽里內(nèi)嵌樣式表代碼。開發(fā)者應(yīng)該養(yǎng)成習(xí)慣,單獨(dú)建立文件,用以存放CSS樣式表。而這也將方便其他開發(fā)者在修改你的代碼時(shí),能迅速完成工作。
3、優(yōu)化CSS代碼
現(xiàn)如今,為網(wǎng)站添加多個(gè)CSS文件的做法已經(jīng)很普遍。但是,當(dāng)網(wǎng)站包含的CSS文件過多時(shí),會(huì)降低網(wǎng)站的響應(yīng)速度。解決辦法是:精簡(jiǎn)代碼并對(duì)多個(gè)CSS文件進(jìn)行優(yōu)化,將其合并成一個(gè)文件。這個(gè)辦法能顯著提升網(wǎng)站的加載速度。此外,有很多工具可以用來優(yōu)化CSS文件,例如CSS Optimizer、Clean CSS等。
4、優(yōu)化JavaScript文件,并將其放到頁(yè)面底部
和CSS一樣,為頁(yè)面添加多個(gè)Javascript文件也是很普遍的做法。但這同樣會(huì)降低網(wǎng)站的響應(yīng)速度。為此,開發(fā)者應(yīng)該精簡(jiǎn)、優(yōu)化這些Javascript文件。
但有一點(diǎn)和CSS不同,瀏覽器通常不支持并行加載。這也就是說,當(dāng)瀏覽器加載Javascript文件時(shí),將不再同時(shí)加載其它內(nèi)容。而這就導(dǎo)致了網(wǎng)頁(yè)的加載速度好像變慢了。
一個(gè)好的解決辦法是:將Javascript文件的加載順序放在最后。為了實(shí)現(xiàn)這一目標(biāo),開發(fā)者可以把Javascript代碼放在HTML文檔的底部,而最好的位置是放在接近/body標(biāo)簽的地方。
5、善用標(biāo)題元素
h1 到 h6這些元素用來突出頁(yè)面的重點(diǎn)內(nèi)容。這有助于用戶更加關(guān)注頁(yè)面的重點(diǎn)部分。對(duì)于博客,推薦使用h1標(biāo)簽來突出博客標(biāo)題。因?yàn)?,博客?biāo)題幾乎是頁(yè)面中最重要的部分。
6、在合適的地方使用合適的HTML標(biāo)簽
HTML標(biāo)簽是構(gòu)造規(guī)范內(nèi)容結(jié)構(gòu)的關(guān)鍵。例如,em標(biāo)簽用來強(qiáng)調(diào)重點(diǎn)內(nèi)容。p標(biāo)簽適用于突出文章段落。如果想要在段落間加空行,就不要使用br /標(biāo)簽。
對(duì)于一組相關(guān)的元素,建議使用ul、ol或 dl標(biāo)簽。但是,不要錯(cuò)誤的使用blockquote標(biāo)簽,因?yàn)樗臼怯脕矶x塊應(yīng)用的。
7、避免濫用div標(biāo)簽
并不是所有塊元素都應(yīng)該用div標(biāo)簽來創(chuàng)建。例如,可以在內(nèi)聯(lián)元素的屬性里添加display:block,將其以塊元素的方式顯示。
8、使用列表創(chuàng)建導(dǎo)航
使用ul列表標(biāo)簽,再配以相應(yīng)的CSS樣式,可以創(chuàng)建美觀的導(dǎo)航菜單。
9、別忘了封閉標(biāo)簽
現(xiàn)在,每當(dāng)我回憶起在大學(xué)里學(xué)到的關(guān)于Web開發(fā)的第一堂課時(shí),教授提到的HTML結(jié)構(gòu)的重要性總是浮現(xiàn)在我的腦海。根據(jù)W3C標(biāo)準(zhǔn),標(biāo)簽應(yīng)該被封閉。那是因?yàn)?,在一些瀏覽器下,如果沒有按照標(biāo)準(zhǔn)來將標(biāo)簽封閉,會(huì)出現(xiàn)顯示不正常的問題。而這一情況在IE6、7和8里尤為明顯。
10、標(biāo)簽小寫語(yǔ)法
標(biāo)簽采用小寫語(yǔ)法是一項(xiàng)行業(yè)標(biāo)準(zhǔn)。雖然大寫語(yǔ)法并不影響頁(yè)面的顯示效果,但是,代碼的可讀性很差。下面這段代碼可讀性就非常差:
11、為圖片標(biāo)簽添加alt屬性
在img標(biāo)簽里,alt屬性通常非常有用。因?yàn)樗阉饕嫱ǔo法直接抓取圖片文件。但是,如果開發(fā)者在alt屬性里添加了圖片的描述內(nèi)容,將會(huì)方便搜索引擎的抓取。
12、在表格里使用label和fieldset
為了提高代碼質(zhì)量,并讓用戶容易理解表格內(nèi)容,我們應(yīng)該用label 和 fieldset標(biāo)簽創(chuàng)建表格元素。
13、將瀏覽器兼容代碼標(biāo)明信息并相互分開
對(duì)一名Web開發(fā)者來說,跨瀏覽器兼容是一個(gè)被重點(diǎn)關(guān)注的問題。通常,開發(fā)者會(huì)針對(duì)不同的瀏覽器來編碼,也即是CSS hack。但是,如果開發(fā)者在編碼時(shí),能注明代碼為哪一個(gè)版本的瀏覽器所寫,會(huì)為以后的維護(hù)工作帶來極大方便。下面就是一個(gè)很好的示例:
14、避免過度注釋
作為一名開發(fā)者,在代碼中添加注釋是一個(gè)好習(xí)慣,能方便理解并易于維護(hù)。這在其它編程語(yǔ)言如PHP、JAVA 和 C#里很普遍。但是,HTML/XHTML是文本標(biāo)記語(yǔ)言,非常容易理解。因此,無需為每行代碼都添加注釋。
15、測(cè)試代碼
推薦開發(fā)者使用W3C文本標(biāo)記驗(yàn)證服務(wù)來測(cè)試代碼。它是一個(gè)高效的測(cè)試工具,能幫助你發(fā)現(xiàn)頁(yè)面中存在的錯(cuò)誤。而且,它還能從頁(yè)面錯(cuò)誤出發(fā),幫你定位到相應(yīng)的代碼。這一點(diǎn)通常在編碼完成后很難做到。但開發(fā)者需要注意的是,驗(yàn)證通過的代碼并非就是性能優(yōu)異的代碼。
以上就是分享的Web前端開發(fā)中應(yīng)該遵循的開發(fā)原則。希望這些開發(fā)語(yǔ)言對(duì)從事Web前端的小伙伴們有幫助。
簡(jiǎn)單來說呢,html5+是hbulider利用自己的IDE結(jié)合不同平臺(tái)的借口再加上html5的東西開發(fā)出來的一套框架,它有自己的使用規(guī)范,它允許和提供了一些借口和函數(shù)來讓web開發(fā)者實(shí)現(xiàn)原聲app所能實(shí)現(xiàn)的功能,Dcloud(開發(fā)hublider的公司)還在hublider提供了云打包
功能,幾乎是打包發(fā)布,幫那些不熟悉原生開發(fā)的開發(fā)人員節(jié)省了很多時(shí)間,國(guó)內(nèi)類似的還有Apicloud(提供了很多原生模塊,而且編譯發(fā)布什么的要比hbulider好一些,SDK更新的比較勤,維護(hù)還是做的很不錯(cuò)的,最近在和Dcloud打官司)。hublider的native.js就是一個(gè)接口庫(kù),調(diào)里面的接口就可以利用hbulider為你實(shí)現(xiàn)的和原生api結(jié)合的一些功能。
react native 是fb之前內(nèi)部維護(hù)一個(gè)利用react.js開發(fā)app的一套框架,前不久開源了。由于是大公司的東西,維護(hù)和文檔也非常齊全,再加上是新東西,一出來就變得非常火。