web前端筆試題面試題匯總+前端優(yōu)化總結
《web前端筆試題面試題匯總+前端優(yōu)化總結》由會員分享,可在線閱讀,更多相關《web前端筆試題面試題匯總+前端優(yōu)化總結(43頁珍藏版)》請在裝配圖網上搜索。
前端是龐大的 包括 HTML CSS Javascript Image Flash 等等各種各樣的資源 前端優(yōu)化是復雜的 針對方方面面的資源都有不同的方式 那么 前端優(yōu)化的目的是什么 1 從用戶角度而言 優(yōu)化能夠讓頁面加載得更快 對用 戶的操作響應得更及時 能夠給用戶提供更為友好的體驗 2 從服務商角度而言 優(yōu)化能夠減少頁面請求數 或者 減小請求所占帶寬 能夠節(jié)省可觀的資源 總之 恰當的優(yōu)化不僅能夠改善站點的用戶體驗并且能 夠節(jié)省相當的資源利用 前端優(yōu)化的途徑有很多 按粒度大致可以分為兩類 第 一類是頁面級別的優(yōu)化 例如 HTTP 請求數 腳本的無阻塞 加載 內聯(lián)腳本的位置優(yōu)化等 第二類則是代碼級別的優(yōu)化 例如 Javascript 中的 DOM 操作優(yōu)化 CSS 選擇符優(yōu)化 圖片 優(yōu)化以及 HTML 結構優(yōu)化等等 另外 本著提高投入產出比 的目的 后文提到的各種優(yōu)化策略大致按照投入產出比從大 到小的順序排列 一 頁面級優(yōu)化 1 減少 HTTP 請求數 這條策略基本上所有前端人都知道 而且也是最重要最 有效的 都說要減少 HTTP 請求 那請求多了到底會怎么樣 呢 首先 每個請求都是有成本的 既包含時間成本也包含 資源成本 一個完整的請求都需要經過 DNS 尋址 與服務器 建立連接 發(fā)送數據 等待服務器響應 接收數據這樣一個 漫長 而復雜的過程 時間成本就是用戶需要看到或者 感受 到這個資源是必須要等待這個過程結束的 資源上由于每個 請求都需要攜帶數據 因此每個請求都需要占用帶寬 另外 由于瀏覽器進行并發(fā)請求的請求數是有上限的 具體參見此 處 因此請求數多了以后 瀏覽器需要分批進行請求 因 此會增加用戶的等待時間 會給用戶造成站點速度慢這樣一 個印象 即使可能用戶能看到的第一屏的資源都已經請求完 了 但是瀏覽器的進度條會一直存在 減少 HTTP 請求數的主要途徑包括 1 從設計實現層面簡化頁面 如果你的頁面像百度首頁一樣簡單 那么接下來的規(guī)則 基本上都用不著了 保持頁面簡潔 減少資源的使用時最直 接的 如果不是這樣 你的頁面需要華麗的皮膚 則繼續(xù)閱 讀下面的內容 2 合理設置 HTTP 緩存 緩存的力量是強大的 恰當的緩存設置可以大大的減少 HTTP 請求 以有啊首頁為例 當瀏覽器沒有緩存的時候訪 問一共會發(fā)出 78 個請求 共 600 多 K 數據 如圖 1 1 而當 第二次訪問即瀏覽器已緩存之后訪問則僅有 10 個請求 共 20 多 K 數據 如圖 1 2 這里需要說明的是 如果直接 F5 刷 新頁面的話效果是不一樣的 這種情況下請求數還是一樣 不過被緩存資源的請求服務器是 304 響應 只有 Header 沒 有 Body 可以節(jié)省帶寬 怎樣才算合理設置 原則很簡單 能緩存越多越好 能 緩存越久越好 例如 很少變化的圖片資源可以直接通過 HTTP Header 中的 Expires 設置一個很長的過期頭 變化不頻繁 而又可能會變的資源可以使用 Last Modifed 來做請求驗證 盡可能的讓資源能夠在緩存中待得更久 關于 HTTP 緩存的 具體設置和原理此處就不再詳述了 有興趣的可以參考下列 文章 HTTP1 1 協(xié)議中關于緩存策略的描述 Fiddler HTTP Performance 中關于緩存的介紹 3 資源合并與壓縮 如果可以的話 盡可能的將外部的腳本 樣式進行合并 多個合為一個 另外 CSS Javascript Image 都可以用相應 的工具進行壓縮 壓縮后往往能省下不少空間 4 CSS Sprites 合并 CSS 圖片 減少請求數的又一個好辦法 5 Inline Images 使用 data URL scheme 的方式將圖片嵌入到頁面或 CSS 中 如果不考慮資源管理上的問題的話 不失為一個好辦法 如果是嵌入頁面的話換來的是增大了頁面的體積 而且無法 利用瀏覽器緩存 使用在 CSS 中的圖片則更為理想一些 6 Lazy Load Images 這條策略實際上并不一定能減少 HTTP 請求數 但是卻 能在某些條件下或者頁面剛加載時減少 HTTP 請求數 對于 圖片而言 在頁面剛加載的時候可以只加載第一屏 當用戶 繼續(xù)往后滾屏的時候才加載后續(xù)的圖片 這樣一來 假如用 戶只對第一屏的內容感興趣時 那剩余的圖片請求就都節(jié)省 了 有啊首頁曾經的做法是在加載的時候把第一屏之后的圖 片地址緩存在 Textarea 標簽中 待用戶往下滾屏的時候才 惰性 加載 2 將外部腳本置底 前文有談到 瀏覽器是可以并發(fā)請求的 這一特點使得 其能夠更快的加載資源 然而外鏈腳本在加載時卻會阻塞其 他資源 例如在腳本加載完成之前 它后面的圖片 樣式以 及其他腳本都處于阻塞狀態(tài) 直到腳本加載完成后才會開始 加載 如果將腳本放在比較靠前的位置 則會影響整個頁面 的加載速度從而影響用戶體驗 解決這一問題的方法有很多 在這里有比較詳細的介紹 這里是譯文和更詳細的例子 而 最簡單可依賴的方法就是將腳本盡可能的往后挪 減少對并 發(fā)下載的影響 3 異步執(zhí)行 inline 腳本 inline 腳本對性能的影響與外部腳本相比 是有過之而 無不及 首頁 與外部腳本一樣 inline 腳本在執(zhí)行的時候 一樣會阻塞并發(fā)請求 除此之外 由于瀏覽器在頁面處理方 面是單線程的 當 inline 腳本在頁面渲染之前執(zhí)行時 頁面 的渲染工作則會被推遲 簡而言之 inline 腳本在執(zhí)行的時 候 頁面處于空白狀態(tài) 鑒于以上兩點原因 建議將執(zhí)行時 間較長的 inline 腳本異步執(zhí)行 異步的方式有很多種 例如 使用 script 元素的 defer 屬性 存在兼容性問題和其他一些問 題 例如不能使用 document write 使用 setTimeout 此外 在 HTML5 中引入了 Web Workers 的機制 恰恰可以解決此 類問題 4 Lazy Load Javascript 隨著 Javascript 框架的流行 越來越多的站點也使用起 了框架 不過 一個框架往往包括了很多的功能實現 這些 功能并不是每一個頁面都需要的 如果下載了不需要的腳本 則算得上是一種資源浪費 既浪費了帶寬又浪費了執(zhí)行花費 的時間 目前的做法大概有兩種 一種是為那些流量特別大 的頁面專門定制一個專用的 mini 版框架 另一種則是 Lazy Load YUI 則使用了第二種方式 在 YUI 的實現中 最初只 加載核心模塊 其他模塊可以等到需要使用的時候才加載 5 將 CSS 放在 HEAD 中 如果將 CSS 放在其他地方比如 BODY 中 則瀏覽器有可 能還未下載和解析到 CSS 就已經開始渲染頁面了 這就導致 頁面由無 CSS 狀態(tài)跳轉到 CSS 狀態(tài) 用戶體驗比較糟糕 除 此之外 有些瀏覽器會在 CSS 下載完成后才開始渲染頁面 如果 CSS 放在靠下的位置則會導致瀏覽器將渲染時間推遲 6 異步請求 Callback 在某些頁面中可能存在這樣一種需求 需要使用 script 標簽來異步的請求數據 類似 Javascript Callback 函數 function myCallback info do something here HTML cb 返回的內容 myCallback Hello world 像以上這種方式直接在頁面上寫 對頁面的性能也 是有影響的 即增加了頁面首次加載的負擔 推遲了 DOMLoaded 和 window onload 事件的觸發(fā)時機 如果時效性 允許的話 可以考慮在 DOMLoaded 事件觸發(fā)的時候加載 或者使用 setTimeout 方式來靈活的控制加載的時機 7 減少不必要的 HTTP 跳轉 對于以目錄形式訪問的 HTTP 鏈接 很多人都會忽略鏈 接最后是否帶 假如你的服務器對此是區(qū)別對待的話 那 么你也需要注意 這其中很可能隱藏了 301 跳轉 增加了多 余請求 具體參見下圖 其中第一個鏈接是以無 結尾的方 式訪問的 于是服務器有了一次跳轉 8 避免重復的資源請求 這種情況主要是由于疏忽或頁面由多個模塊拼接而成 然后每個模塊中請求了同樣的資源時 會導致資源的重復請 求 二 代碼級優(yōu)化 1 Javascript 1 DOM DOM 操作應該是腳本中最耗性能的一類操作 例如增 加 修改 刪除 DOM 元素或者對 DOM 集合進行操作 如果 腳本中包含了大量的 DOM 操作則需要注意以下幾點 a HTML Collection 在腳本中 document images document forms getElementsByTagName 返回的都是 HTMLCollection 類型的集合 在平時使用的時 候大多將它作為數組來使用 因為它有 length 屬性 也可以 使用索引訪問每一個元素 不過在訪問性能上則比數組要差 很多 原因是這個集合并不是一個靜態(tài)的結果 它表示的僅 僅是一個特定的查詢 每次訪問該集合時都會重新執(zhí)行這個 查詢從而更新查詢結果 所謂的 訪問集合 包括讀取集合的 length 屬性 訪問集合中的元素 因此 當你需要遍歷 HTML Collection 的時候 盡量將它 轉為數組后再訪問 以提高性能 即使不轉換為數組 也請 盡可能少的訪問它 例如在遍歷的時候可以將 length 屬性 成員保存到局部變量后再使用局部變量 b Reflow 代碼塊的行為實際上是修改了代碼塊中 的執(zhí)行環(huán)境 將 obj 放在了其作用域鏈的最前端 在 with 代 碼塊中訪問非局部變量是都是先從 obj 上開始查找 如果沒 有再依次按作用域鏈向上查找 因此使用 with 相當于增加 了作用域鏈長度 而每次查找作用域鏈都是要消耗時間的 過長的作用域鏈會導致查找性能下降 因此 除非你能肯定在 with 代碼中只訪問 obj 中的屬性 否則慎用 with 替代的可以使用局部變量緩存需要訪問的屬 性 3 避免使用 eval 和 Function 每次 eval 或 Function 構造函數作用于字符串表示的源 代碼時 腳本引擎都需要將源代碼轉換成可執(zhí)行代碼 這是 很消耗資源的操作 通常比簡單的函數調用慢 100 倍以 上 eval 函數效率特別低 由于事先無法知曉傳給 eval 的 字符串中的內容 eval 在其上下文中解釋要處理的代碼 也 就是說編譯器無法優(yōu)化上下文 因此只能有瀏覽器在運行時 解釋代碼 這對性能影響很大 Function 構造函數比 eval 略好 因為使用此代碼不會影 響周圍代碼 但其速度仍很慢 此外 使用 eval 和 Function 也不利于 Javascript 壓縮工 具執(zhí)行壓縮 4 減少作用域鏈查找 前文談到了作用域鏈查找問題 這一點在循環(huán)中是尤其 需要注意的問題 如果在循環(huán)中需要訪問非本作用域下的變 量時請在遍歷之前用局部變量緩存該變量 并在遍歷結束后 再重寫那個變量 這一點對全局變量尤其重要 因為全局變 量處于作用域鏈的最頂端 訪問時的查找次數是最多的 低效率的寫法 全局變量 var globalVar 1 function myCallback info for var i 100000 i 每次訪問 globalVar 都需要查找到作用域鏈最頂端 本例中需要訪問 100000 次 globalVar i 更高效的寫法 全局變量 var globalVar 1 function myCallback info 局部變量緩存全局變量 var localVar globalVar for var i 100000 i 訪問局部變量是最快的 localVar i 本例中只需要訪問 2 次全局變量 globalVar localVar 此外 要減少作用域鏈查找還應該減少閉包的使用 5 數據訪問 Javascript 中的數據訪問包括直接量 字符串 正則表達 式 變量 對象屬性以及數組 其中對直接量和局部變量 的訪問是最快的 對對象屬性以及數組的訪問需要更大的開 銷 當出現以下情況時 建議將數據放入局部變量 a 對任何對象屬性的訪問超過 1 次 b 對任何數組成員的訪問次數超過 1 次 另外 還應當盡可能的減少對對象以及數組深度查找 6 字符串拼接 在 Javascript 中使用 號來拼接字符串效率是比較低的 因為每次運行都會開辟新的內存并生成新的字符串變量 然 后將拼接結果賦值給新變量 與之相比更為高效的做法是使 用數組的 join 方法 即將需要拼接的字符串放在數組中最后 調用其 join 方法得到結果 不過由于使用數組也有一定的開 銷 因此當需要拼接的字符串較多的時候可以考慮用此方法 關于 Javascript 優(yōu)化的更詳細介紹請參考 Write Efficient Javascript PPT Efficient JavaScript 2 CSS 選擇符 在大多數人的觀念中 都覺得瀏覽器對 CSS 選擇符的解 析式從左往右進行的 例如 toc A color 444 這樣一個選擇符 如果是從右往左解析則效率會很高 因為第一個 ID 選擇基本上就把查找的范圍限定了 但實際 上瀏覽器對選擇符的解析是從右往左進行的 如上面的選擇 符 瀏覽器必須遍歷查找每一個 A 標簽的祖先節(jié)點 效率并 不像之前想象的那樣高 根據瀏覽器的這一行為特點 在寫 選擇符的時候需要注意很多事項 有人已經一一列舉了 詳 情參考此處 3 HTML 對 HTML 本身的優(yōu)化現如今也越來越多的受人關注了 詳情可以參見這篇總結性文章 4 Image 壓縮 圖片壓縮是個技術活 不過現如今這方面的工具也非常 多 壓縮之后往往能帶來不錯的效果 具體的壓縮原理以及 方法在 Even Faster Web Sites 第 10 章有很詳細的介紹 有興趣的可以去看看 總結 本文從頁面級以及代碼級兩個粒度對前端優(yōu)化的各種方 式做了一個總結 這些方法基本上都是前端開發(fā)人員在開發(fā) 的過程中可以借鑒和實踐的 除此之外 完整的前端優(yōu)化還 應該包括很多其他的途徑 例如 CDN Gzip 多域名 無 Cookie 服務器等等 由于對于開發(fā)人員的可操作性并不強大 在此也就不多敘述了 詳細的可以參考 Yahoo 和 Google 的 這些 金科玉律 1 Javascript 簡介 HTML 是純靜態(tài)的的頁面 而 Javascript 讓頁面有了動態(tài)的效 果 比如 OA 中模塊的拖拉 所有的瀏覽器都會內置 Javascript 的解釋器 1992 年 Nombas 公司開發(fā)出 C 減減的嵌入式腳本語言 這 是最好的 HTML 頁面的腳本語言 Netscape 為了擴展其瀏覽器的功能 開發(fā)了一套 LiveScript 并與 1995 年與 SUN 公司聯(lián)合把其改名為 javascript 它的主要 目的是處理一些輸入的有效性驗證 而之前這個工作是留給 perl 之類的服務器端語言完成 在以前使用電話線調制解調 器 28 8kb s 的時代 如此慢的與服務器交互 這絕對是一件 很痛苦的事情 Javascript 的出現 解決了這個問題 因為它 的驗證是基于客戶端的 微軟公司早期版本的瀏覽器僅支持自己的 vbscript 但后來 不得不加入 javascript IE3 中搭載 Javascipt 的克隆版本 命名為 jscript 在一次技術會議中 sun microsoft netscape 公司聯(lián)合制定 了 ECMA Script 標準 在 2005 前 網頁上提示框 廣告越來越多 把 javascipt 濫 用 使 javascript 背上了大量的罪名 2005 年 google 公司的網上產品 google 地圖 gmail google 搜索建議 等使得 ajax 興起 而 javascript 便 是 ajax 最重要的元素之一 Javascript 有三個部分組成 ECMAScript DOM BOM WEB 標準 網頁主要有三部分組成 結構 HTML XHTML 表現 CSS 行為 DOM ECMA 2 ECMA 腳本 Javascript 的語法 1 區(qū)分大小寫 2 弱類型變量 var age 10 var name dd 3 每行結尾的分號可有可無 但建議還是加上 4 注釋與 java 相同 變量 變量是通過 var 關鍵字來聲明的 Variable 變量的命名規(guī)則與 java 一致 注釋有三種 這個只能注釋單行 2 1 javascript 的 Hello world document write 是寫在文檔的最前面 2 2 slice substring subtr Slice 和 substring 2 5 指的是從第 3 為開始 取 5 2 3 個 數 其中 slice 的參數可以為負 Substr 2 5 指的是從第 3 為開始 取 5 個數 但 ECMAscript 沒有對該方法進行標準化 因此盡量少使用該方 法 2 3 indexOf 和 lastIndexOf isNan typeOf indexOf i 從前往后 i 在第幾位 indexOf i 3 可選參數 從第幾個字符開始往后找 lastIndexOf i 從后往前 i 在第幾位 lastIndexOf i 3 從后往前 i 在第幾位 如果沒找到 則返回 1 String 類型的變量 在 Java 中 用 符號表示字符串 用 表示單個字符 而在 javascript 中這兩種都可以 Nan not a number Alert nan nan 返回 false 因此不推薦使用 nan 本身 推薦 函數 isNan Alert isNanN ab 返回 false typeof 運算符 var stmp test alert typeof stmp 輸出 string alert type of 1 輸出 number 此外 還有 boolean undefined object 如果是引用類型或者 null 值 null 值返回 object 這其實是 ecmascript 的一個錯誤 當聲明的變量未初始化的時候 它的值就是 undefined 當沒 有這個變量的時候 typeof 變 返回的值也是 undefined 但是沒聲明的變量是不能參與計 算的 當函數無明確返回值時 返回的也是 undefined Function a Alert a undefined 返回 true Alert null undefined 返回 true 2 4 數值計算 var mynum1 23 345 var mynum2 45 var mynum3 34 var mynum4 9e5 科學計數法 為 9 10 五次方 var fNumber 123 456 alert fNumber toExponential 1 保留的小數點數 1 2e 2 alert fNumber toExponential 2 1 23e 2 5 布爾值 var married true alert 1 typeof married Boolean married true alert 2 typeof married String 6 類型轉換 轉換成 string 類型有三種方式 var a 3 var b a var c a toString var d student a toString var a 11 document write a toString 2 轉成 2 進制 document write a toString 3 轉成 3 進制 如果不是數值 則轉換報錯 parseInt document write parseInt 1red6 返回 1 后面非 數值的將全部忽略 document write parseInt 53 5 返回 53 document write parseInt 0 xC 直接十進制 轉換 12 document write parseInt isaacshun NAN document write parseInt 011 8 返回 9 document write parseInt 011 10 指定為十進 制 返回 11 parseFloat 與 parseInt 類似 2 7 數組 var aMap new Array China USA Britain aMap 20 Korea alert aMap length aMap 10 aMap 20 aMap 10 返回 undefined document write aMap join 用 來連接 var sFruit apple pear peach orange var aFruit sFruit split var aFruit apple pear peach orange alert aFruit reverse toString var aFruit pear apple peach orange aFruit sort var stack new Array stack push red stack push green stack push blue document write stack toString var vItem stack pop blue document write vItem document write stack toString red green 2 8 if 語句 首先獲取用戶的一個輸入 并用 Number 強制轉換為數字 var iNumber Number prompt 輸入一個 5 到 100 之間的數 字 第二個參數 用于顯示輸入框的默認值 if isNaN iNumber 判斷輸入的是否是數字 NaN Not a Number document write 請確認你的輸入正確 else if iNumber 100 iNumber 5 判斷輸入的 數字范圍 document write 你輸入的數字范圍不在 5 和 100 之間 else document write 你輸入的數字是 iNumber 2 9 switch iWeek parseInt prompt 輸入 1 到 7 之間的整數 switch iWeek case 1 document write Monday break case 2 document write Tuesday break case 3 document write Wednesday break case 4 document write Thursday break case 5 document write Friday break case 6 document write Saturday break case 7 document write Sunday break default document write Error 2 10 while 語句 var i iSum 0 while i 100 iSum i i alert iSum do while for break continue 與 JAVA 語法一致 2 11 函數 function ArgsNum return arguments length document write ArgsNum isaac 25 document write ArgsNum document write ArgsNum 3 從這個例子可以看出 方法可以沒有參數 也可以沒有返回 值 但是照樣可以傳入參數和返回值 2 12 Date 對象 var myDate1 new Date 運行代碼前的時間 for var i 0 i 1 var isKHTML sUserAgent indexOf KHTML 1 sUserAgent indexOf Konqueror 1 sUserAgent indexOf AppleWebKit 1 檢測 IE Mozilla var isIE sUserAgent indexOf compatible 1 var isMoz sUserAgent indexOf Gecko 1 檢測操作系統(tǒng) var isWin navigator platform Win32 navigator platform Windows var isMac navigator platform Mac68K navigator platform MacPPC navigator platform Macintosh var isUnix navigator platform X11 if isOpera document write Opera if isKHTML document write KHTML if isIE document write IE if isMoz document write Mozilla if isWin document write Windows if isMac document write Mac if isUnix document write Unix 1 13 Global 對象 其實 isNan paraseInt 等都是 Global 對象的方法 EncodeURI 因為有效的 URI 不能包含某些字符 如空 格 這個方法就是用于將這個字符轉換成 UTF 8 編碼 使瀏覽器可以接受他們 Var suil file a html Alert encodeURI suil a html 即將空格編碼成 20 Eval 方法 Eval alert hi 當解析程序發(fā)現 eval 時 它將把參數解析成真正的 ECMA script 語句 然后插入該語句所在位置 Global 除了有內置方法外 還有很多內置的屬性 如 undefined nan Array String Number Date RegExp 等 1 14 Math 對象 Max 方法 min 方法 ceil floor round sqrt random Max 1 2 3 min 1 2 3 4 想取到 1 10 的數據 Math floor Math random 10 1 2 9 的數據 Math floor Math random 9 2 3 1 getElementsByTagName function searchDOM 放在函數內 頁面加載完成后才用的 onload 加載 這時如果把 alert 這句改成用 document write 則會把 原內容覆蓋掉 因為是后面才執(zhí)行的 var oLi document getElementsByTagName li 輸出長度 標簽名稱以及某項的文本節(jié)點值 alert oLi length oLi 0 tagName oLi 3 childNodes 0 nodeValue var oUl document getElementsByTagName ul var oLi2 oUl 1 getElementsByTagName li alert oLi2 length oLi2 0 tagName oLi2 1 childNodes 0 nodeValue 客戶端語言 HTML JavaScript CSS 服務器端語言 ASP NET JSP PHP 3 2 getElementById var oLi document getElementById cssLi oLi style backgroundColor yellow 輸出標簽名稱以及文本節(jié)點值 alert oLi tagName oLi childNodes 0 nodeValue 3 2 getElementsByName alert document getElementsByName a length 3 3 訪問子節(jié)點 function myDOMInspector var oUl document getElementById myList 獲取 標記 var DOMString if oUl hasChildNodes 判斷是否有子節(jié)點 var oCh oUl childNodes for var i 0 i oCh length i 逐一查找 DOMString oCh i nodeName n alert DOMString 4 訪問父節(jié)點 nodeName 如果為文本節(jié)點 則返回 text tagName 如果為文本節(jié)點 則返回 undefined function myDOMInspector var myItem document getElementById myDearFood alert myItem parentNode tagName function myDOMInspector var myItem document getElementById myDearFood var parentElm myItem parentNode while parentElm className colorful 一路往 上找 alert parentElm tagName 糖醋排骨 圓籠粉蒸肉 泡菜魚 板栗燒雞 麻婆豆腐 訪問兄弟節(jié)點 function myDOMInspector var myItem document getElementById myDearFood 訪問兄弟節(jié)點 var nextListItem myItem nextSibling var preListItem myItem previousSibling alert nextListItem tagName preListItem tagName 在 Firefox 中不支持 但是 IE 中卻是支持的 3 6 第一個 最后一個 子節(jié)點 function nextSib node var tempLast node parentNode lastChild 判斷是否是最后一個節(jié)點 如果是則返回 null if node tempLast return null var tempObj node nextSibling 逐一搜索后面的兄弟節(jié)點 直到發(fā)現元素節(jié)點為止 while tempObj nodeType 1 三目運算符 如果是元素節(jié)點則返回節(jié)點本身 否 則返回 null return tempObj nodeType 1 tempObj null function prevSib node var tempFirst node parentNode firstChild 判斷是否是第一個節(jié)點 如果是則返回 null if node tempFirst return null var tempObj node previousSibling 逐一搜索前面的兄弟節(jié)點 直到發(fā)現元素節(jié)點為止 while tempObj nodeType 1 return tempObj nodeType 1 tempObj null function myDOMInspector var myItem document getElementById myDearFood 獲取后一個元素兄弟節(jié)點 var nextListItem nextSib myItem 獲取前一個元素兄弟節(jié)點 var preListItem prevSib myItem alert 后一項 nextListItem null nextListItem firstChild nodeValue null 前一項 preListItem null preListItem firstChild nodeValue null nodeType 元素 element 1 屬性 attr 2 文本 text 3 注釋 comments 8 文檔 document 9 function showAttr var btnShowAttr document getElementById btnShowAttr 演示按鈕 有很多屬性 var attrs btnShowAttr attributes for var i 0 i attrs length i var attr attrs i alert nodeType attr nodeType attribute 的 nodeType 2 alert attr attr alert attr name attr name attr value function showDocument alert nodeType document nodeType 9 alert nodeName document nodeName alert document 3 7 getAttribute setAttribute function myDOMInspector 獲取圖片 var myImg document getElementsByTagName img 0 獲取圖片 title 屬性 alert myImg getAttribute title function changePic 獲取圖片 var myImg document getElementsByTagName img 0 設置圖片 src 和 title 屬性 myImg setAttribute src 02 jpg myImg setAttribute title 紫荊公寓 3 8 創(chuàng)建新節(jié)點 function createP var op document createElement p var otext document createTextNode HHHHH op appendChild otext op setAttribute style text align center document body appendChild op 創(chuàng)建完節(jié)點 就馬上會影響到下面的操作 比如 P 的數量就會多 1 個 3 9 刪除節(jié)點 需要注意的是標簽之間的父子關系 function deleteP var oP document getElementsByTagName p 0 oP parentNode removeChild oP 刪除節(jié)點 3 10 替換節(jié)點 function replaceP var oOldP document getElementsByTagName p 0 var oNewP document createElement p 新建節(jié)點 var oText document createTextNode 這是一個感人肺 腑的故事 oNewP appendChild oText oOldP parentNode replaceChild oNewP oOldP 替換節(jié)點 3 11 插入節(jié)點 function insertP var oOldP document getElementsByTagName p 0 var oNewP document createElement p 新建節(jié)點 var oText document createTextNode 這是一個感人肺 腑的故事 oNewP appendChild oText oOldP parentNode insertBefore oNewP oOldP 插入節(jié)點 沒有 insertAfter 但是可以自己寫一個 function insertAfter newElement targetElement var oParent targetElement parentNode 首先找 到目標元素的父元素 if oParent lastChild targetElement 如果目標元 素已經是最后一個子元素了 oParent appendChild newElement 則直接 用 appendChild 加到子元素列表的最后 else 否則用 insertBefore 插入到目標元素的下一個兄弟元素之前 oParent insertBefore newElement targetElement nextSib ling function insertP var oOldP document getElementById myTarget var oNewP document createElement p 新建節(jié)點 var oText document createTextNode 這是一個感人肺 腑的故事 oNewP appendChild oText insertAfter oNewP oOldP 插入節(jié)點 其實這個也是通過 insertBefore 原理來實現的 3 12 cloneNode deepBoolean 復制并返回當前節(jié)點的復制節(jié)點 這個復制得到的節(jié)點是一 個孤立的節(jié)點 不在 document 樹中 復制原來節(jié)點的屬性 值 包括 ID 屬性 所以在把這個新節(jié)點加到 document 之前 一定要修改 ID 屬性 以便使它保持唯一 當然如果 ID 的 唯一性不重要可以不做處理 這個方法支持一個布爾參數 當 deepBoolean 設置 true 時 復制 當前節(jié)點的所有子節(jié)點 包括該節(jié)點內的文本 11111 p document getElementById mypara pclone p cloneNode true p parentNode appendChild pclone 3 12 文檔碎片 function insertPs var aColors red green blue magenta yellow chocolate black aquamarine lime fuchsia brass azure brown bronze deeppink aliceblue gray copper coral feldspar orang e orchid pink plum quartz purple var oFragment document createDocumentFragment 創(chuàng)建文檔碎片 for var i 0 i aColors length i var oP document createElement p var oText document createTextNode aColors i oP appendChild oText oFragment appendChild oP 將節(jié)點 先添加到碎片中 document body appendChild oFragment 最后一 次性添加到頁面 3 13 innerHTML function myDOMInnerHTML var myDiv document getElementById myTest alert myDiv innerHTML 直接顯示 innerHTML 的內容 修改 innerHTML 可直接添加代碼 myDiv innerHTML innerHTML 可同時顯示沒有的代碼 3 14 換皮膚 myUL1 color 0000FF font family Arial font weight bold myUL2 color FF0000 font family Georgia Times New Roman Times serif function check var oMy document getElementsByTagName ul 0 oMy className oMy className myUL1 myUL2 myUL1 修改 CSS 類 HTML JavaScript CSS 4 表格與表單 4 1 動態(tài)添加行 window onload function var oTr document getElementById member insertRow 2 插入一 行 var aText new Array aText 0 document createTextNode fresheggs aText 1 document createTextNode W610 aText 2 document createTextNode Nov 5th aText 3 document createTextNode Scorpio aText 4 document createTextNode 1038818 for var i 0 i aText length i var oTd oTr insertCell i oTd appendChild aText i 4 2 修改單元格內容 window onload function var oTable document getElementById member oTable rows 3 cells 4 innerHTML lost 修改單元格內容 4 3 動態(tài)刪除 parentElement 是 IE dom parentNode 是標準 DOM window onload function var oTable document getElementById member oTable deleteRow 2 刪除一行 后面的行號自動補齊 指從 table 中的第 2 行開始進 行刪除 oTable rows 2 deleteCell 1 刪除一個單 元格 后面的也自動補齊 function myDelete var oTable document getElementById member 刪除該行 this parentNode parentNode parentNode remove Child this parentNode parentNode window onload function var oTable document getElementById member var oTd 動態(tài)添加 delete 鏈接 for var i 1 i oTable rows length i oTd oTable rows i insertCell 5 oTd innerHTML delete oTd firstChild onclick myDelete 添加刪 除事件 4 4 動態(tài)刪除列 function deleteColumn oTable iNum 自定義刪除列函數 即每行刪除相應單元格 for var i 0 i oTable rows length i oTable rows i deleteCell iNum window onload function var oTable document getElementById member deleteColumn oTable 2 4 5 控制 textarea 的字符個數 function LessThan oTextArea 返回文本框字符個數是否符號要求的 boolean 值 return oTextArea value length oTextArea getAttribute maxlength 5 BOM 模型 瀏覽器對象模型 可以對瀏覽器窗口進行訪問和操作 使用 BOM 開發(fā)者可以移動窗口 改變狀態(tài)欄中的文本等與頁面 內容不相關的操作 Window 對象 這里可以用 window frames 0 或者用 windows frames topFrame 來引用框架 也可以用 topl 來代 替 window 屬性 Top frames 0 window 對象可以忽略 提供的方法有 moveto moveBy resizeTo resizeBy 等方法 但 盡量避免使用它們 因為會對用戶瀏覽產生影響 Open 方法 除了 open 方法 還有 alert comfirm prompt 方法 狀態(tài)欄 Settimeout 與 setInterval Settimeout 下面的代碼都是在 1 秒鐘后顯示一條警告 Settimeout alert aa 1000 Settimeout function alert aa 1000 如果要還未執(zhí)行的暫停 可調用 clearTimeOut 方法 Var si Settimeout function alert aa 1000 clearTimeout si setInterval History 向后一頁 window history go 1 等于 history back 向前一頁 window history go 1 等于 history forword Document LastModified title URL 屬性都是比較常用 Location 對象 Navigator 對象 Screen 對象 6 事件 6 1 冒泡型事件 function add sText var oDiv document getElementById display oDiv innerHTML sText 輸出點擊順序 body onclick add body div onclick add div p onclick add p Click Me 先執(zhí)行最里面的 p 再往外執(zhí)行 6 2 監(jiān)聽函數 window onload function var oP document getElementById myP 找到對 象 oP onclick function 設置事件監(jiān)聽函數 alert 我被點擊了 Click Me Function a oP onclick a 這樣會先把 a 函數加載到緩存 不是最佳方案 Var A Function oP onclick a 這樣只有在 onclick 事件發(fā)生的時候 加載該函數 若以上的監(jiān)聽函數 在 onclick 的時候 需要執(zhí)行多個函數 那就只能用以下的方法 IE 標準 function fnClick alert 我被點擊了 oP detachEvent onclick fnClick 點擊了一次 后刪除監(jiān)聽函數 var oP 聲明在函數外 這樣就可以兩個函數一起使用 window onload function oP document getElementById myP 找到對象 oP attachEvent onclick fnClick 添加監(jiān)聽函 數 Click Me 也可以添加多個監(jiān)聽器 oP attachEvent onclick fnClick1 添加監(jiān) 聽函數 1 oP attachEvent onclick fnClick2 添加監(jiān) 聽函數 2 執(zhí)行順序為 fnClick2 fnClick1 但是以上的監(jiān)聽器均為 IE 中的標準 而符合標準 DOM firefox 的監(jiān)聽器如下 oP addEventListener click fnClick1 false 添加監(jiān)聽函數 1 oP addEventListener click fnClick2 false 添加監(jiān)聽函數 2 因此這種方式在 Firefox 中支持 而在 IE 中不支持 為了兼容性 可這樣寫 if el addEventListener el addEventListener click KindDisableMenu false else if el attachEvent el attachEvent onclick KindDisableMenu 第三個參數為 useCapture 而 useCapture 這個參數就是在控制這時候兩個 click 事件 的先後順序 如果是 false 那就會使用 bubbling 他是從 內而外的流程 所以會先執(zhí)行藍色元素的 click 事件再執(zhí)行 紅色元素的 click 事件 如果是 true 那就是 capture 和 bub- 配套講稿:
如PPT文件的首頁顯示word圖標,表示該PPT已包含配套word講稿。雙擊word圖標可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設計者僅對作品中獨創(chuàng)性部分享有著作權。
- 關 鍵 詞:
- web 前端 筆試 試題 匯總 優(yōu)化 總結
裝配圖網所有資源均是用戶自行上傳分享,僅供網友學習交流,未經上傳用戶書面授權,請勿作他用。
鏈接地址:http://ioszen.com/p-12962433.html