DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> HTML基礎知識 >> HTML和Xhtml >> html/css基礎篇——html代碼編寫過程中的幾個警惕點(必看)
html/css基礎篇——html代碼編寫過程中的幾個警惕點(必看)
編輯:HTML和Xhtml      日期:2016/12/23 10:01:20

本文想說的警惕點與浏覽器兼容無關,主要是幾個本人在項目中遇到的幾個小問題的總結,問題雖小,但是卻有時很困擾人,在此記錄一下,如果後期有此類問題會持續添加到這裡。

1.內聯標簽之間的空格

正常情況下書寫html代碼的時候都有換行、縮進等習慣,比如

XML/HTML Code復制內容到剪貼板
  1. <head>  
  2.     <meta charset="utf-8">  
  3.     <style>  
  4.     html,body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td{   
  5.     margin: 0;   
  6.     padding:0;   
  7.     }   
  8.     #myDIV {   
  9.       width: 200px;   
  10.       height: 200px;   
  11.       background-color: #ff0;   
  12.     }   
  13.     #myDIV > div{   
  14.       width: 50px;   
  15.       height: 50px;   
  16.       display: inline-block;   
  17.       background-color: #f00;   
  18.     }   
  19.     </style>  
  20.   
  21.   </head>  
  22.   <body>  
  23.     <div id="myDIV">  
  24.       <div>div1</div>  
  25.       <div>div2</div>  
  26.     </div>  
  27.   </body>  

顯示效果為

中間有一個空白。原因是如果兩個內聯標簽(或者設置display:inline或inline-block)之間有連續的空格符、回車符、換行符,則會這些符號會被默認處理為一個空格符號。

比如我們在兩個div標簽之內加入"    ddd      dd      d        ",效果如下,無論有多少個相連的空白符號,最終呈現的效果都只有一個空格符

這個和在內聯元素中直接寫入字符類似

但是內聯元素會去掉頭部和尾部的空白字符。

所以需要提示的是:

內聯元素排列時如果需要避免標簽之間的空白則需要使標簽緊密相連。

內聯元素要填寫內容時盡量使用.innerText或.textContent(Firefox不支持innerText,但是支持該屬性)。

非要在html代碼中寫入空白,請使用html的空格表示方法&nbsp;

說道這裡,我想有些人對內聯元素理解有偏差。所謂內聯是和所謂的“塊”對立的。內聯元素不成塊的,感覺就像水流一樣,遇到阻礙就環繞而行。比如源碼

XML/HTML Code復制內容到剪貼板
  1. <div id="myDIV">  
  2.       <div>div1</div> ddd      dd      d       <div>div2</div>  
  3.       <span>    d      dd      d       </span>  
  4.     </div>  

顯示效果

span裡面的內容被分成了兩段,不是一個完整的塊了。

2.body標簽默認的margin邊框

 這個沒有什麼說的,現代浏覽器(支持CSS3)和IE8的body都默認了一個css樣式margin:8px。其他有的標簽也是有這樣的,這裡不舉例了。很多時候我們都不需要,需要一般的項目樣式開頭都有一個類似的設置。

XML/HTML Code復制內容到剪貼板
  1. html,body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td{   
  2.     margin: 0;   
  3.     padding:0;   
  4.     }  

3.特殊空白字符導致顯示異常

舉個例子,下面的源碼中看似沒有問題

XML/HTML Code復制內容到剪貼板
  1. <!DOCTYPE html>  
  2. <html>  
  3.   <head>  
  4.     <meta charset="utf-8">  
  5.     <style>  
  6.     html,body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td{   
  7.     margin: 0;   
  8.     padding:0;   
  9.     }   
  10.     *{   
  11.       -webkit-box-sizing: border-box;   
  12.       -moz-box-sizing: border-box;   
  13.       box-sizing: border-box;   
  14.     }   
  15.     #myDIV {   
  16.     width: 200px;   
  17.     height: 40px;   
  18.     background-color: #ff0;   
  19.     }   
  20.     #myDIV a{   
  21.       float: left;   
  22.       width: 200px;   
  23.       background-color: #f00;   
  24.     }   
  25.     </style>  
  26.   
  27.   </head>  
  28.   <body>  
  29.     <div class="tabbable" id="tabs" style="border:none;">  
  30.       <!-- 頁面標簽列表 -->  
  31.       <div id="myDIV" style="">  
  32.        <a data-toggle="tab" href="#tab-content-0" >test0</a>  
  33.       </div>  
  34.     </div>  
  35.   </body>  
  36. </html>  

實際上a標簽前面的有一個非正常的的空白字符,顯示效果如下

a的寬度和#myDIV的寬度應該是相同的,且a是浮動,顯示效果卻換行了,這也太讓人抓狂了,有麼有。

正常的顯示效果是

我們來看一下這個非正常的空白是啥。

第一個是非正常的空格,其URI組件編碼為"%E3%80%80"

第二個是正常的空格,其URI組件編碼為"%20"

第三個是正常的Tab建,其URI組件編碼為"%20%20%20%20",實際上就是4個空格。

看出來了吧。所以有的時候再網站中拷貝的代碼運行效果異常可能就是這個原因導致的。

未完待續,後期如果想到其他的點補上。也希望童鞋們提一些相關的點,本人一定補上。

以上這篇html/css基礎篇——html代碼編寫過程中的幾個警惕點(必看)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

原文地址:http://www.cnblogs.com/chuaWeb/p/5053644.html

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved