整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          你知道嗎?Web前端也有規范的!

          你知道嗎?Web前端也有規范的!

          注“教授學苑”,期待帶給你快樂的開發知識!

          在這個web亂世中,還有一種規范可以去遵守!

          黃金法則

          不管有多少參與者,代碼都應該像同一個人所寫。

          HTML規范

          語法

          • 使用兩個空格的 soft tabs — 這是保證代碼在各種環境下顯示一致的唯一方式

          • 嵌套的節點應該縮進(兩個空格)

          • 在屬性上,使用雙引號,不要使用單引號

          • 不好在自動閉合標簽結尾處使用斜線

          • 不要忽略可選的關閉標簽

          HTML5 doctype

          在每個 HTML 頁面開頭使用這個簡單地 doctype 來啟用標準模式,使其每個瀏覽器中盡可能一致的展現。

          Language 屬性

          鼓勵網站作者在 html 元素上指定 lang 屬性,來指出頁面的語言。這樣做有助于語言合成工具來確定發音方式,以及幫助翻譯工具決定使用的規則,等等

          字符編碼

          通過聲明一個明確的字符編碼,讓瀏覽器輕松、快速的確定適合網頁內容的渲染方式。這樣做之后,需要避免在 HTML 中出現字符實體,直接提供字符與文檔一致的編碼(通常是 UTF-8)

          IE 兼容模式

          Internet Explorer 支持使用兼容性 <meta>

          標簽來指定使用什么版本的 IE 來渲染頁面。如果不是特殊需要,通常通過 edge mode 來通知 IE 使用最新的兼容模式。

          引入 CSS 和 JavaScript

          根據 HTML5 規范, 通常在引入 CSS 和 JavaScript 時不需要指明 type,因為 text/css text/javascript分別是他們的默認值。

          實用高于完美

          盡量遵循 HTML 標準和語義,但是不應該以浪費實用性作為代價。任何時候都要用盡量小的復雜度和盡量少的標簽來解決問題。

          屬性順序

          HTML 屬性應該按照特定的順序出現以保證易讀性。

          • class

          • id, name

          • data-*

          • src, for, type, href, value

          • title, alt

          • role, aria-*

          Classes 是為高可復用組件設計的,所以他們處在第一位。Ids 更加具體而且應該盡量少使用(例如, 頁內書簽),所以他們處在第二位。

          Boolean 屬性

          不要為 Boolean 屬性添加取值

          減少標簽數量

          在編寫 HTML 代碼時,需要盡量避免多余的父節點。很多時候,需要通過迭代和重構來使 HTML 變得更少

          JavaScript 生成標簽

          在 JavaScript 文件中生成標簽讓內容變得更難查找,更難編輯,性能更差。應該盡量避免這種情況的出現。

          CSS規范

          語法

          • 使用兩個空格的 soft tabs — 這是保證代碼在各種環境下顯示一致的唯一方式。

          • 使用組合選擇器時,保持每個獨立的選擇器占用一行。

          • 為了代碼的易讀性,在每個聲明的左括號前增加一個空格。

          • 聲明塊的右括號應該另起一行。

          • 每條聲明:后應該插入一個空格。

          • 每條聲明應該只占用一行來保證錯誤報告更加準確。

          • 所有聲明應該以分號結尾。雖然最后一條聲明后的分號是可選的,但是如果沒有他,你的代碼會更容易出錯。

          • 逗號分隔的取值,都應該在逗號之后增加一個空格。

          • 不要在顏色值 rgb(), rgba(), hsl(), hsla() ,和 rect() 中增加空格。

          • 不要在屬性取值或者顏色參數前面添加不必要的 0。

          • 所有的十六進制值都應該使用小寫字母。

          • 盡可能使用短的十六進制數值

          • 為選擇器中得屬性取值添加引號。

          • 不要為 0 指明單位。

          聲明順序

          相關的屬性聲明應該以下面的順序分組處理:

          1. Positioning

          2. Box model 盒模型

          3. Typographic 排版

          4. Visual 外觀

          Positioning 處在第一位,因為他可以使一個元素脫離正常文本流,并且覆蓋盒模型相關的樣式。盒模型緊跟其后,因為他決定了一個組件的大小和位置。

          其他屬性只在組件 內部 起作用或者不會對前面兩種情況的結果產生影響,所以他們排在后面。

          媒體查詢位置

          盡量將媒體查詢的位置靠近他們相關的規則。不要將他們一起放到一個獨立的樣式文件中,或者丟在文檔的最底部。這樣做只會讓大家以后更容易忘記他們。

          不要使用@import

          與link相比import更慢,需要額外的頁面請求,并且可能引發其他的意想不到的問題。應該避免使用他們,而選擇其他的方案:

          • 使用多個link元素

          • 使用 CSS 預處理器例如 Sass 或 Less 將樣式編譯到一個文件中

          • 使用 Rails, Jekyll 或其他環境提供的功能,來合并 CSS 文件。

          前綴屬性

          當使用廠商前綴屬性時,通過縮進使取值垂直對齊以便多行編輯。

          單條聲明的聲明塊

          在一個聲明塊中只包含一條聲明的情況下,為了易讀性和快速編輯可以考慮移除其中的換行。所有包含多條聲明的聲明塊應該分為多行。

          屬性簡寫

          堅持限制屬性取值簡寫的使用,屬性簡寫需要你必須顯式設置所有取值。常見的屬性簡寫濫用包括:

          • padding

          • margin

          • font

          • background

          • border

          • border-radius

          大多數情況下,我們并不需要設置屬性簡寫中包含的所有值。例如,HTML 頭部只設置上下的 margin,所以如果需要,只設置這兩個值。過度使用屬性簡寫往往會導致更混亂的代碼,其中包含不必要的重寫和意想不到的副作用。

          LESS 和 SASS 中的嵌套

          避免不必要的嵌套??梢赃M行嵌套,不意味著你應該這樣做。只有在需要給父元素增加樣式并且同時存在多個子元素時才需要考慮嵌套。

          LESS 和 SASS 中的運算符

          為了提高代碼可讀性,在數學運算外增加括號,并且在取值,變量和運算符之間增加空格。

          代碼注釋

          代碼是由人來編寫和維護的。保證你的代碼是描述性的,包含好的注釋,并且容易被他人理解。好的代碼注釋傳達上下文和目標。不要簡單地重申組件或者 class 名稱。

          Class 命名

          • 保持 Class 命名為全小寫,可以使用短劃線(不要使用下劃線和 camelCase 命名)。短劃線應該作為相關類的自然間斷。

          • 避免過度使用簡寫。

          • Class 的命名應該盡量短,也要盡量明確

          • 使用有意義的名稱;使用結構化或者作用目標相關,而不是抽象的名稱。

          • 命名時使用最近的父節點或者父 class 作為前綴

          • 這些規則在創建 Sass 和 Less 變量名時同樣有用。

          選擇器

          • 使用 classes 而不是通用元素標簽來優化渲染性能

          • 避免在經常出現的組件中使用一些屬性選擇器

          • 減少選擇器的長度,每個組合選擇器選擇器的條目應該盡量控制在 3 個以內。

          • 在必要的情況下使用后代選擇器 (例如,沒有使用帶前綴 classes 的情況).

          代碼組織

          • 以組件為單位組織代碼。

          • 制定一個一致的注釋層級結構。

          • 使用一致的空白來分割代碼塊,這樣做在查看大的文檔時更有優勢。

          • 當使用多個 CSS 文件時,通過組件而不是頁面來區分他們。頁面會被重新排列組合,而組件是可以移動的。

          關注“教授學苑”,期待帶給你快樂的開發知識!

          件是 Web 開發的方向,現在的熱點是 JavaScript 組件,但是 HTML 組件未來可能更有希望。 本文就介紹 HTML 組件的基礎知識:自定義元素(custom elements)。

          一、瀏覽器處理

          我們一般都使用標準的 HTML 元素。

          <p>Hello World</p>
          

          上面代碼中,<p>就是標準的 HTML 元素。

          如果使用非標準的自定義元素,會有什么結果?

          <greeting>Hello World</greeting>
          

          上面代碼中,<greeting>就是非標準元素,瀏覽器不認識它。這段代碼的運行結果是,瀏覽器照常顯示Hello World,這說明瀏覽器并沒有過濾這個元素。

          現在,為自定義元素加上樣式。

          greeting {
           display: block;
           font-size: 36px;
           color: red;
          }
          

          運行結果如下。

          接著,使用腳本操作這個元素。

          function customTag(tagName, fn){
           Array
           .from(document.getElementsByTagName(tagName))
           .forEach(fn);
          }
          function greetingHandler(element) {
           element.innerHTML='你好,世界';
          } 
          customTag('greeting', greetingHandler);
          

          運行結果如下。

          這說明,瀏覽器對待自定義元素,就像對待標準元素一樣,只是沒有默認的樣式和行為。這種處理方式是寫入 HTML5 標準的。

          “User agents must treat elements and attributes that they do not understand as semantically neutral; leaving them in the DOM (for DOM processors), and styling them according to CSS (for CSS processors), but not inferring any meaning from them.”

          上面這段話的意思是,瀏覽器必須將自定義元素保留在 DOM 之中,但不會任何語義。除此之外,自定義元素與標準元素都一致。

          事實上,瀏覽器提供了一個HTMLUnknownElement對象,所有自定義元素都是該對象的實例。

          var tabs=document.createElement('tabs');
          tabs instanceof HTMLUnknownElement // true
          tabs instanceof HTMLElement // true
          

          上面代碼中,tabs是一個自定義元素,同時繼承了HTMLUnknownElement和HTMLElement接口。

          獲取方式:

          1.在你手機的右上角有【關注】選項,或點擊我的頭像,點擊關注?。P注我)

          2.關注后,手機客戶端點擊我的主頁面,右上角有私信,請私信發我:編程

          電腦已經設置好了關鍵詞自動回復,自動領取就好了!這幾天上萬個消息,真的回復不過來,所以回復的時候請注意關鍵詞!

          其實做為一個開發者,有一個學習的氛圍跟一個交流圈子特別重要這里請私信我“編程”不管你是小白還是大牛歡迎入住大家一起交流成長。小編會在里面不定期分享干貨源碼,包括我精心整理的一份零基礎教程。歡迎各位感興趣的的小伙伴。

          學習思路:


          二、HTML import

          有了自定義元素,就可以寫出語義性非常好的 HTML 代碼。

          <share-buttons>
           <social-button type="weibo">
           <a href="...">微博</a>
           </social-button>
           <social-button type="weixin">
           <a href="...">微信</a>
           </social-button>
          </share-buttons>
          

          上面的代碼,一眼就能看出語義。

          如果將<share-buttons>元素的樣式與腳本,封裝在一個 HTML 文件share-buttons.html之中,這個元素就可以復用了。

          使用的時候,先引入share-buttons.html。

          <link rel="import" href="share-buttons.html">
          

          然后,就可以在網頁中使用<share-buttons>了。

          <article>
           <h1>Title</h1>
           <share-buttons/>
           ... ...
          </article>
          

          HTML imports 的更多用法可以參考教程(1,2)。目前只有 Chrome 瀏覽器支持這個語法。


          三、Custom Elements 標準

          HTML5 標準規定了自定義元素是合法的。然后,W3C 就為自定義元素制定了一個單獨的 Custom Elements 標準。

          它與其他三個標準放在一起—- HTML Imports,HTML Template、Shadow DOM—-統稱為 Web Components 規范。目前,這個規范只有 Chrome 瀏覽器支持。

          Custom Elements 標準對自定義元素的名字做了限制。

          “自定義元素的名字必須包含一個破折號(-)所以<x-tags>、<my-element>和<my-awesome-app>都是正確的名字,而<tabs>和<foo_bar>是不正確的。這樣的限制使得 HTML 解析器可以分辨那些是標準元素,哪些是自定義元素?!?/p>

          注意,一旦名字之中使用了破折號,自定義元素就不是HTMLUnknownElement的實例了。

          var xTabs=document.createElement('x-tabs');
          xTabs instanceof HTMLUnknownElement // false
          xTabs instanceof HTMLElement // true
          

          Custom Elements 標準規定了,自定義元素的定義可以使用 ES6 的class語法。

          // 定義一個 <my-element></my-element>
          class MyElement extends HTMLElement {...}
          window.customElements.define('my-element', MyElement);
          

          上面代碼中,原生的window.customElements對象的define方法用來定義 Custom Element。該方法接受兩個參數,第一個參數是自定義元素的名字,第二個參數是一個 ES6 的class。

          這個class使用get和set方法定義 Custom Element 的某個屬性。

          class MyElement extends HTMLElement {
           get content() {
           return this.getAttribute('content');
           }
           set content(val) {
           this.setAttribute('content', val);
           }
          }
          

          有了這個定義,網頁之中就可以插入<my-element>了。

          <my-element content="Custom Element">
           Hello
          </my-element>
          

          處理腳本如下。

          function customTag(tagName, fn){
           Array
           .from(document.getElementsByTagName(tagName))
           .forEach(fn);
          }
          function myElementHandler(element) {
           element.textConent=element.content;
          }
          customTag('my-element', myElementHandler);
          

          運行結果如下。

          ES6 Class 的一個好處是,可以很容易地寫出繼承類。

          class MyNewElement extends MyElement {
           // ...
          }
          customElements.define('my-new-element', MyNewElement);
          

          今天的教程就到這里,更多用法請參考谷歌的官方教程。

          . HTML

          1. img標記屬于什么類型元素?

          答案:屬于行內(inline)元素.

          2.結構標記有哪些?他們與div有什么相同之處,又有什么不同之處?

          答案:header,nav,section,aside,footer,article

          都是用來做布局的,但結構標記提高了語義性和可讀性.

          3. 行內元素,塊元素,空元素有哪些?

          答案:

          (1)行內元素:

          a, span,i,img,b ,s,u,sup,sub,label

          (2)塊元素:

          div ,dl,dt,dd,ul,li,ol,p,h1,h2,h3,h4,h5,結構標記

          (3)空元素:

          br-換行,hr-水平分割線

          4. 什么是前端?

          答案

          用HTML/CSS/JavaScript以及更多的框架技術,編寫網站頁面、App應用、小程序、2D&3D游戲、Web VR&AR等應用,通過內容設計、交互動畫、數據操作構建項目與用戶的交互界面。前端工程師在項目中可以與UI設計師和后臺程序員合作,實現設計意圖并調用后臺接口,也可以獨立工作完成強用戶交互的各類應用。

          5. HTML、CSS、JavaScript的作用是什么,為什么會產生這三種語言?

          答案:這三種語言都是用來編寫網頁的,HTML用于搭建網頁結構展示內容,CSS用于修飾HTML元素,JavaScript用于添加網頁的交互驗證。

          6. 說說HTML5,CSS3的新特性,平時使用過哪些?

          答案:

          H5新特性:

          結構標記(header,footer,section,article,aside,nav),新表單元素(url,email,number,date,month,color等),canvas,audio,video,地理定位,拖放,web存儲,Web Workers,WebSocket等。

          CSS3新特性:

          復雜選擇器器(屬性選擇器,偽類選擇器,偽元素選擇器,兄弟選擇器等),邊框倒角,邊框陰影,漸變,轉換,過渡,動畫,彈性盒子,媒體查詢技術等。

          7、Doctype 作用? 嚴格模式與混雜模式如何區分?它們有何意義?

          (1)、 聲明位于文檔中的最前面,處于 標簽之前。告知瀏覽器的解析器,用什么文檔類型 規范來解析這個文檔。

          (2)、嚴格模式的排版和 JS 運作模式是 以該瀏覽器支持的最高標準運行。

          (3)、在混雜模式中,頁面以寬松的向后兼容的方式顯示。模擬老式瀏覽器的行為以防止站點無法工作。

          (4)、DOCTYPE 不存在或格式不正確會導致文檔以混雜模式呈現。

          8、對語義化如何理解?

          答案:用正確的標簽做正確的事情!

          HTML 語義化就是讓頁面的內容結構化,便于對瀏覽器、搜索引擎解析;在沒有樣式 CCS 情況下也以一種文檔格式顯示,并且是容易閱讀的。搜索引擎的爬蟲依賴于標記來確定上下文和各個關鍵字的權重,利于 SEO。使閱讀源代碼的人對網站更容易將網站分塊,便于閱讀維護理解。

          9、iframe 有那些缺點?

          iframe 會阻塞主頁面的 Onload 事件;

          iframe 和主頁面共享連接池,而瀏覽器對相同域的連接有限制,所以會影響頁面的并行加載。使用 iframe 之前需要考慮這兩個缺點。如果需要使用 iframe,最好是通過 javascript 動態給 iframe 添加 src 屬性值,這樣可以可以繞開以上兩個問題。

          10.對 WEB 標準以及 W3C 的理解與認識?

          答案:

          標簽閉合、標簽小寫、不亂嵌套、提高搜索機器人搜索幾率、使用外鏈 css 和 js 腳本、結構與行為表現的分離、文件下載與頁面速度更快、內容能被更多的用戶所訪問、內容能被更廣泛的設備所訪問、更少的代碼和組件,容易維護、改版方便,不需要變動頁面內容、提供打印版本而不需要復制內容、提高網站易用性.

          11.XHTML 和 HTML 有什么區別?

          答案:

          HTML 是一種基本的 WEB 網頁設計語言,XHTML 是一個基于 XML 的置標語言最主要的不同:

          XHTML 元素必須被正確地嵌套。

          XHTML 元素必須被關閉。標簽名必須用小寫字母。

          XHTML 文檔必須擁有根元素。

          12.img 標簽上 title 與 alt 屬性的區別是什么?

          答案:alt ,當圖片不顯示時,在圖片位置所顯示的文字。

          title,鼠標移入到元素上時,為該元素添加提示信息。

          13.你如何對網站的文件和資源進行優化?

          答案:解決方案包括:

          文件合并

          文件最小化/文件壓縮

          使用 CDN 托管

          緩存的使用.

          二. CSS3

          1.隱藏網頁中的元素有幾種方式?這些方法有什么區別?

          答案:三種方法,

          display:none; 脫離文檔流,不占頁面空間,會改變頁面布局。

          visivility:hidden ;不會脫離文檔流,不會改變頁面布局,仍占頁面空間

          opacity:0,該元素隱藏起來了,但不會改變頁面布局,并且,如果該元素已經綁定一些事件,如click事件,那么點擊該區域,也能觸發點擊事件

          2.如何解決子元素的上外邊距溢出?

          答案:在父元素的第一個子元素位置處添加一個空的table標記.

          3.常用來設置透明度的方式有幾種?他們之間有何區別?

          答案:opacity或rgba

          opacity能設置與元素相關各種顏色的透明度

          rgba()只能設置當前某一種顏色的透明度

          4.浮動會對父元素的高度帶來什么影響?如何解決這個問題?

          答案:子元素一旦浮動,父元素的高度為0,在父元素最后一個子元素位置處添加一個空的塊級元素,并設置其clear屬性值為both.

          .clear:after{

          display:block;

          content:””;

          clear:both;

          }


          5.哪些元素默認有外邊距?

          答案:body,p,h1-h6,ul,ol,dl,pre

          6.網頁中如何定義錨點?如何連接到錨點位置?

          答案:a標記用name定義錨點,其他標記用id屬性定義錨點,

          連接到錨點的位置:href="#錨點名稱"

          7.框模型默認的計算方式是什么?要改變默認的計算方式用哪個屬性及值?

          答案:

          實際占地寬度=左右外邊距+左右邊框+左右內邊距+width

          實際占地高度=上下外邊距+上下邊框+上下內邊距+height

          改變計算方式 box-sizing:border-box


          8.實現時針轉動效果需要用到CSS中哪些關鍵技術?

          答案:旋轉,動畫,絕對定位


          9.設置行內元素居中對齊用什么屬性?

          答案:text-align:center


          10.如果要將表單中控件的值提交給服務器必須為控件設置什么屬性?

          答案:name和value屬性


          11.transition和animation的區別?

          答案:

          Animation和transition大部分屬性是相同的,他們都是隨時間改變元素的屬性值,他們的主要區別是transition需要觸發一個事件才能改變屬性,

          而animation不需要觸發任何事件的情況下也會隨時間改變屬性值,并且transition為2幀,從from .... to,而animation可以一幀一幀的,也可以理解為一個animation是由多個transition組成。


          12. 如何實現水平垂直居中?

          答案:

          1、定位+外邊距 盒子寬高已知, position: absolute; left: 50%; top: 50%; margin-left:-自身一半寬度; margin-top: -自身一半高度;

          2、定位+transform 盒子高寬已知,

          #container{ position:relative; border:1px solid red; width:800px; height:600px; }

          #center{ width:100px; height:100px; background:blue; position:absolute; top:50%; left:50%; transform: translate(-50%,-50%); }

          3、flex 布局

          父級:

          display: flex;

          align-items: center;

          justify-content: center;


          13. 盒子模型你是怎么理解的?

          答案:

          元素框處理元素內容,內邊距外邊距以及邊框的計算方式。

          盒子模型有兩種,W3C和IE盒子模型

          (1)w3c的盒模型width=content,不包括margin,padding,border

          (2)IE盒模型width=content+padding+border

          (3)box-sizng border-box在已設定的寬度和高度之內去設定padding和border

          content-box在已設定的高度和寬度之外設置padding和border

          14. src和href的區別?

          答案:

          (1)href:

          href是Hypertext Reference的縮寫,表示超文本引用。用來建立當前元素和文檔之間的鏈接。

          并行下載該文檔,不會停止對當前文檔的處理

          (2)src:

          src是source的縮寫,src指向的內容會嵌入到文檔當前標簽所在位置

          如img、script、iframe當瀏覽器解析到該元素時,會暫停瀏覽器的渲染,直到該資源加載完畢。

          15. 說出link和import的區別?

          答案:

          (1)使用方法不同:

          link一般在html頭部定義,作為html標簽,鏈接資源,主要用于鏈接外部的樣式表

          import一般定義在css內部,并且一定要在其他所有規則之前,也就是一般寫在文件頭部,并且專門拿來鏈css的。

          (2)加載順序差別

          import比link延遲一些,它會等到頁面下載完后才加載,因而可能會產生閃爍

          16. 改變頁面元素位置的定位方式及他們的區別?

          答案:

          relative 相對定位 相對于自身原來位置進行偏移,仍處于標準文檔流中;

          absolute 絕對定位 相對于最近的已定位的祖先元素, 有已定位(指position不是static的元素)祖先元素, 以最近的祖先元素為參考標準。如果無已定位祖先元素, 以body元素為偏移參照, 完全脫離文檔流;

          fixed 固定定位的元素會相對于視窗來定位,這意味著即便頁面滾動,它還是會停留在固定的位置。固定定位也會脫離文檔流。

          17. display有哪些值,說明他們的作用?

          答案:

          display的取值可以是none/inline/block/inline-block/table

          none:元素隱藏不可見,并且元素也不占頁面空間。

          Inline:元素將呈現行內元素的特點,多個元素在一行中顯示,不允許修改尺寸,也不能設置垂直外邊距。

          block:元素將呈現塊級元素的特點,每個元素獨占一行,允許修改尺寸。

          inline-block:元素將呈現行內塊元素的特點,多個元素在一行中顯示,但是可以修改尺寸。

          table:元素將呈現表格的特點,由內容決定表格的顯示方式。元素獨占一行,允許修改尺寸。

          18. 有兩個div,外框和內框高度寬度都不定,內框垂直水平居中,利用css如何實現?

          答案:.center{

          display:flex;

          justify-content:center;

          align-items:center;

          }

          19. 說說em和rem的區別

          答案:rem是基于html元素的字體大小來決定,而em則根據使用它的元素的字體大小決定(很多人錯誤以為是根據父類元素,實際上是元素繼承了父類的屬性才會產生的錯覺)

          20、瀏覽器的內核分別是什么?


          答案:IE 瀏覽器的內核 Trident、Mozilla 的 Gecko、Chrome 的 Blink(WebKit 的分支)、 Opera 內核原為 Presto,現為 Blink;


          21、為什么要初始化 CSS 樣式?

          因為瀏覽器的兼容問題,不同瀏覽器對有些標簽的默認值是不同的,如果沒對 CSS 初始化往往會出現瀏覽器之間的頁面顯示差異。當然,初始化樣式會對 SEO 有一定的影響,但力求影響最小的情況下初始化。最簡單的初始化方法就是: * {padding: 0; margin: 0;} (不建議)淘寶的樣式初始化: body, h1, h2, h3, h4, h5, h6, hr, p,, dl, dt, dd, ul, ol, li, pre, form, fieldset, legend, button, input, textarea, th, td { margin:0; padding:0; }

          body, button, input, select, textarea { font:12px/1.5tahoma, arial, /5b8b/4f53; }

          h1, h2, h3, h4, h5, h6{ font-size:100%; }

          ul, ol{ list-style:none;}

          a{text-decoration:none; }

          a:hover {text-decoration:underline; }

          img{ border:0;}

          button,input, select,textarea{ font-size:100%; }

          table { border-collapse:collapse; border-spacing:0; }


          22、CSS哪些屬性可以繼承?優先級算法如何計算? CSS3 新增偽類有那些?

          答案:

          可繼承的樣式: font-size ,font-family ,color, background等;

          不可繼承的樣式:border, padding ,margin ,width ,height ;


          優先級就近原則,同權重情況下以最近者為準;

          優先級為: !important > id > class > tag

          important 比 內聯優先級高


          CSS3 新增偽類:

          :first-child 選擇屬于其父元素的首個元素。

          :last-child 選擇屬于其父元素的最后一個元素。

          :only-child 選擇屬于其父元素唯一的元素。

          :nth-child(n) 選擇屬于其父元素的任意一個子元素。

          :empty 選擇沒有子元素的元素。

          :not(selector) 將滿足指定選擇器的元素給排除在外。


          23.描述 css reset 的作用。

          答案:reset 重置瀏覽器為元素設置的默認樣式,瀏覽器的種類不同,樣式可能不同,重置是為了讓他們統一樣式。

          24.清除浮動帶來影響的幾種方式,各自的優缺點

          答案:

          1、直接設置父元素高度,但不是每次都知道父元素的高度。

          2、設置父元素也浮動,但不是任何時候父元素都需要浮動,而且浮動會影響后續元素。

          3、為父元素設置 overflow屬性,但如果有內容需要溢出顯示的話,也會一同被隱藏。

          4、在父元素中,追加空子元素,并設置其clear:both,但頁面中會多出一個空元素。

          5、用內容生成的方式:after{content:””;display:block;clear:both;}

          25.px 和 em 的區別

          px 和 em 都是長度單位,區別是,px 的值是固定的,指定是多少就是多少,計算比較容易。em 得值不是固定的,并且 em 會繼承父級元素的字體大小。

          瀏覽器的默認字體高都是 16px。所以未經調整的瀏覽器都符合: 1em=16px。那么 12px=0.75em, 10px=0.625em

          三. AJAX

          1.用post方式異步向服務器端提交數據時,需要在發送請求前設置什么?提交的數據放在什么位置?

          答案:xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");

          數據放在send()括號中

          2.什么是異步數據加載?

          答案:瀏覽器在向服務器發送請求的時候,不耽誤用戶在網頁上做其它操作,可以同時開啟多個任務,并且可以以無刷新的效果來更改頁面中的局部內容。

          3.異步請求數據的步驟分為哪幾步?

          答案:創建異步對象,綁定監聽事件,創建異步請求,發送異步請求

          var xhr=new XMLHttpRequest();

          xhr.onreadystatechange=function(){

          if(xhr.readyState==4&&xhr.status==200){

          var resText=xhr.responseText;

          }

          }

          xhr.open(method,url,true);

          xhr.send(body);

          4.異步請求中滿足什么條件時才能取出響應的結果數據?

          答案:請求狀態碼為4,響應狀態碼為200時

          5.如何理解JSON?

          答案:

          JSON是JS對象的一種表現方式,即以js對象的數據格式表現出來的字符串,JSON中的兩個api如下:

          將JSON字符串轉換成JSON對象 JSON.parse()

          將JSON對象轉換成JSON字符串 JSON.stringify()

          6. http和https的區別?

          答案:

          http傳輸的數據都是未加密的,也就是明文的

          https協議是由http和ssl協議構建的可進行加密傳輸和身份認證的網絡協議,比http協議的安全性更高。

          兩者使用不同的鏈接方式,端口也不同,一般而言,http協議的端口為80,https的端口為443

          7.列舉幾種常見的3和4開頭的狀態碼以及他們的意義?

          答案:

          301 :永久性重定向

          302 :臨時重定向

          304 :請求資源未被修改,命中緩存

          400 (錯誤請求) 服務器不理解請求的語法。

          403 (禁止) 服務器拒絕請求。

          404 (未找到) 服務器找不到請求的網頁。

          8. 什么是ajax?有哪些優缺點?

          答案:AJAX是“Asynchronous JavaScript and XML”的縮寫。他是指一種創建交互式網頁應用的網頁開發技術。

          優點:

          1.局部刷新頁面,減少用戶心理和實際的等待時間,帶來更好的用戶體驗。

          2.減輕服務器的壓力,按需取數據,最大程度的減少冗余數據請求。

          3.基于xml標準化,并被廣泛支持,不需安裝插件。

          4.促進頁面和數據的分離。

          缺點:

          1.AJAX破壞了瀏覽器的Back和History功能

          2.AJAX安全問題

          3.對搜索引擎支持較弱

          4.破壞程序的異常處理機制

          5.AJAX不是很好支持移動設備


          四. Bootstrap

          1.用bootstrap中的柵格做網頁布局的基本結構是什么?默認將一行分為多少列?

          答案:容器中設置行,行內設置列

          默認將一行分為12個單元格(列)

          2.如何編寫響應式網頁?

          答案:

          (1)聲明viewport元標簽

          (2)所有容器/文字/圖片 使用相對尺寸

          (3)流式布局+彈性布局

          (4)使用CSS3 Media Query技術

          3.同時監聽多個scss文件的命令是什么?

          答案:node-sass -w scss文件夾 –o css文件夾

          4.在scss中如何定義混合器以及引用?

          答案:

          @mixin 混合器名稱{ 樣式聲明 }

          通過@include來使用混合器。

          5.對于各類尺寸的設備,Bootstrap設置的class前綴分別是什么?

          答案

          超小設備手機(<768px):.col-xs-

          小型設備平板電腦(>=768px):.col-sm-

          中型設備臺式電腦(>=992px):.col-md-

          大型設備臺式電腦(>=1200px):.col-lg-

          6.Bootstrap如何設置響應式表格?

          增加class="table-responsive"

          7、使用Bootstrap激活或禁用按鈕要如何操作?

          激活按鈕:給按鈕增加.active的class

          禁用按鈕:給按鈕增加disabled="disabled"的屬性

          8、Bootstrap有哪些關于<img>的class?

          (1).img-rounded 為圖片添加圓角


          (2).img-circle 將圖片變為圓形

          (3).img-thumbnail 縮略圖功能

          (4).img-responsive 圖片響應式 (將很好地擴展到父元素)

          9、Bootstrap中有關元素浮動及清除浮動的class?

          class="clearfix" 清除浮動

          10、Bootstrap如何制作下拉菜單?

          (1)將下拉菜單包裹在class="dropdown"的<div>中;

          (2)在觸發下拉菜單的按鈕中添加:class="btn dropdown-toggle" id="dropdownMenu1" data-toggle="dropdown"

          (3)在包裹下拉菜單的ul中添加:class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1"

          (4)在下拉菜單的列表項中添加:role="presentation"。其中,下拉菜單的標題要添加class="dropdown-header",選項部分要添加tabindex="-1"。

          11、Bootstrap如何制作按鈕組?

          用class="btn-group"的<div>去包裹按鈕組;class="btn-group-vertical"可設置垂直按鈕組。

          12、Bootstrap中的導航都有哪些?

          (1)導航元素:有class="nav nav-tabs"的標簽頁導航,還有class="nav nav-pills"的膠囊式標簽頁導航;

          (2)導航欄:class="navbar navbar-default" role="navigation";

          (3)面包屑導航:class="breadcrumb"


          13、Bootstrap中設置分頁的class?

          默認的分頁:class="pagination"

          14、Bootstrap中如何制作徽章?

          <span class="badge">26</span>

          15、Bootstrap中超大屏幕的作用是什么?

          設置class="jumbotron"可以制作超大屏幕,該組件可以增加標題的大小并增加更多的外邊距。

          16、Bootstrap 網格系統列與列之間的間隙寬度是多少?

          間隙寬度為30px(一個列的每邊分別是15px)。

          17、用Bootstrap,如何設置文字的對齊方式?

          class="text-center" 設置居中文本

          class="text-right" 設置向右對齊文本

          class="text-left" 設置向左對齊文本.


          主站蜘蛛池模板: 中文字幕亚洲乱码熟女一区二区| 日韩人妻精品一区二区三区视频| 国产麻豆剧果冻传媒一区| 日韩视频在线观看一区二区| 国产福利一区二区三区视频在线| 国产美女av在线一区| 国产综合视频在线观看一区| 无码人妻精品一区二区蜜桃网站 | 亚洲日韩AV无码一区二区三区人 | 麻豆亚洲av熟女国产一区二| 精品国产一区二区三区在线观看 | 久久一区二区精品| 在线精品动漫一区二区无广告| 国产在线精品一区在线观看| 国产成人欧美一区二区三区| 国产精品福利一区二区| 麻豆AV一区二区三区| 麻豆天美国产一区在线播放| 色欲精品国产一区二区三区AV| 国产一区二区精品久久岳| 日韩人妻无码一区二区三区综合部| 日韩电影在线观看第一区| 在线日韩麻豆一区| 一区二区三区在线播放视频| 视频一区二区三区免费观看| 日韩一区二区三区在线精品| 色综合视频一区二区三区| 国产日韩高清一区二区三区| 一区二区国产精品| 国产成人无码AV一区二区在线观看 | tom影院亚洲国产一区二区 | 伊人激情AV一区二区三区| 国产丝袜视频一区二区三区| 久久精品一区二区东京热| 亚洲bt加勒比一区二区| 亚洲一区二区三区无码国产| 天堂一区二区三区精品| 能在线观看的一区二区三区| 中文字幕在线播放一区| 一区二区三区视频在线| 亚洲熟妇成人精品一区|