摘要:用戶填寫所有信息后,提交給服務器,等待服務器的回應檢驗數據,是一次性的。移除的元素包括純表現的元素對可用性產生負面影響的元素。網頁的行為層負責回答內容應該如何對事件做出反應這一問題。他是指一種創建交互式網頁應用的網頁開發技術。
AngularJS。
優點:
模板功能強大豐富,并且是聲明式的,自帶了豐富的Angular指令;
是一個比較完善的前端MV*框架,包含模板,數據雙向綁定,路由,模塊化,服務,過濾器,依賴注入等所有功能;
自定義Directive,比jQuery插件還靈活,但是需要深入了解Directive的一些特性,簡單的封裝容易,復雜一點官方沒有提供詳細的介紹文檔,我們可以通過閱讀源代碼來找到某些我們需要的東西,如:在directive使用 $parse;
ng模塊化比較大膽的引入了Java的一些東西(依賴注入),能夠很容易的寫出可復用的代碼,對于敏捷開發的團隊來說非常有幫助,我們的項目從上線到目前,UI變化很大,在摸索中迭代產品,但是js的代碼基本上很少改動。
補充:Angular支持單元測試和e2e-testing。
弊端:
驗證功能錯誤信息顯示比較薄弱,需要寫很多模板標簽,沒有jQuery Validate方便,所以可以自己封裝了驗證的錯誤信息提示;
ngView只能有一個,不能嵌套多個視圖,雖然有 angular-ui/ui-router · GitHub 解決,但是貌似ui-router 對于URL的控制不是很靈活,必須是嵌套式的;
對于特別復雜的應用場景,貌似性能有點問題,特別是在Windows下使用chrome瀏覽器,不知道是內存泄漏了還是什么其他問題,沒有找到好的解決方案,奇怪的是在IE10下反而很快;
這次從1.0.X升級到1.2.X,貌似有比較大的調整,沒有完美兼容低版本,升級之后可能會導致一個兼容性的BUG,具體詳細信息參考官方文檔 AngularJS ,對應的中文版本:Angular 1.0到1.2 遷移指南
ng提倡在控制器里面不要有操作DOM的代碼,對于一些jQuery 插件的使用,如果想不破壞代碼的整潔性,需要寫一些directive去封裝插件,但是現在有很多插件的版本已經支持Angular了,如:jQuery File Upload Demo
Angular 太笨重了,沒有讓用戶選擇一個輕量級的版本,當然1.2.X后,Angular也在做一些更改,比如把route,animate等模塊獨立出去,讓用戶自己去選擇。
什么是AJAX,簡述異步請求與同步請求的不同?AJAX 是一種在無需重新加載整個網頁的情況下,能夠更新部分網頁的技術。
AJAX = 異步 JavaScript 和 XML。
AJAX 是一種用于創建快速動態網頁的技術。
通過在后臺與服務器進行少量數據交換,AJAX 可以使網頁實現異步更新。這意味著可以在不重新加載整個網頁的情況下,對網頁的某部分進行更新。
同步是指:發送方發出數據后,等接收方發回響應以后才發下一個數據包的通訊方式。
用戶填寫所有信息后,提交給服務器,等待服務器的回應(檢驗數據),是一次性的。信息錯誤又要重新填寫!
異步是指:發送方發出數據后,不等接收方發回響應,接著發送下個數據包的通訊方式。當用戶填寫完一條信息后,該信息會自動向服務器提交,然后服務器響應客戶端,在此過程中,用戶依然在填寫表格的信息,即向服務器請求多次,節省了用戶的時間,提高了用戶的體驗。
同步請求:
客戶端請求(等待)->服務端處理->響應->頁面載入
(缺少對象:XMLhttpRequest)
這時候如果有錯誤,只能再次發送請求,再次等待
異步請求:
比如當你填寫郵箱地址的時候,頁面當時就把郵箱地址發送到了服務器(也就是頁面發送了一個請求),服
務器做處理和響應,得到你的郵箱地址填寫重復了,把響應結果發給頁面,在這個過程中你仍然可以填寫其
他內容,這時候服務器會提示你有重復的郵箱地址,在頁面上的表現只是郵箱地址旁別加了一行字或者把整
個文本框標紅,并沒有重新刷你的頁面,所有的填寫錯誤會實時的顯示出來,你也會實時的更正。
這個過程中,你會有整個頁面的刷新,也不會有整個頁面的提交和等待,最后提交,一切都會搞定的
總結:頁面上的操作和服務器端的操作互相之間不會造成阻塞
=====建立異步請求過程的4個步驟:============
a:new一個XHR對象
b:調用open方法
c:send一些數據
d:對過程進行監聽,來知道服務器是不是正確地做出了響應,接著可以做一些事情
閉包就是能夠讀取其他函數內部變量的函數
作用 :一個是前面提到的可以讀取函數內部的變量,另一個就是讓這些變量的值始終保持在內存中。
在一個對象上觸發某類事件(比如單擊onclick事件),如果此對象定義了此事件的處理程序,那么此事件
就會調用這個處理程序,如果沒有定義此事件處理程序或者事件返回true,那么這個事件會向這個對象的父
級對象傳播,從里到外,直至它被處理(父級對象所有同類事件都將被激活),或者它到達了對象層次的最
頂層,即document對象(有些瀏覽器是window)。
打個比方說:你在地方法院要上訴一件案子,如果地方沒有處理此類案件的法院,地方相關部門會幫你繼續
往上級法院上訴,比如從市級到省級,直至到中央法院,最終使你的案件得以處理。
HTML5現在已經不是SGML的子集,主要是關于圖像、位置、存儲、地理定位等功能的增加。
新特性有:
?繪畫canvas元素 ?用于媒介回放的 video 和 audio 元素 ?本地離線存儲 localStorage 長期存儲數據,瀏覽器關閉后數據不丟失; ?sessionStorage 的數據在瀏覽器關閉后自動刪除 ?語意化更好的內容元素,比如 article、footer、header、nav、section ?表單控件,calendar、date、time、email、url、search CSS3實現圓角、,陰影、對文字加特效,增加了更多的CSS選擇器,多背景rgba,新的技術有webworker、websockt、Geolocation。 移除的元素包括: ?純表現的元素 basefont、big、center、font、 s、strike、tt、u; ?對可用性產生負面影響的元素 frame、frameset、noframes。
瀏覽器兼容H5問題解決方案:
IE8/IE7/IE6支持通過document.createElement方法產生的標簽,可以利用這一特性讓這些瀏覽器支持HTML5新標簽,瀏覽器支持新標簽后,還需要添加標簽默認的樣式,當然最好的方式是直接使用成熟的框架:頁面重構怎么操作?
把“未采用CSS,大量使用HTML進行定位、布局,或者雖然已經采用CSS,但是未遵循HTML結構化標準的站點”變成“讓標記回歸標記的原本意義。通過在HTML文檔中使用結構化的標記以及用CSS控制頁面表現,使頁面的實際內容與它們呈現的格式相分離的站點。”的過程就是網站重構
網站為什么要進行重構(網站重構的好處)
a、使頁面加載得更快速;
b、降低帶寬帶來的費用,節約成本;
c、讓你在修改設計時更有效率而代價更低;
d、幫助你的整個站點保持視覺的一致性;
e、更利于搜索引擎的檢索(符合SEO的規范);
f、令站點更容易被各種瀏覽器和用戶
編寫 CSS、讓頁面結構更合理化,提升用戶體驗,實現良好的頁面效果和提升性能。
最準確的網頁設計思路是把網頁分成三個層次,即:結構層、表示層、行為層。
網頁的結構層(structural layer)由HTML或XHTML之類的標記語言負責創建。標簽,也就是那些出現在尖括號里的單詞,對網頁內容的語義含義做出了描述,但這些標簽不包含任何關于如何顯示有關內容的信息。例如,P 標簽表達了這樣一種語義:“這是一個文本段。”
網頁的表示層(presentation layer)由CSS負責創建。 CSS對“如何顯示有關內容”的問題做出了回答。
網頁的行為層(behavior layer)負責回答“內容應該如何對事件做出反應”這一問題。這是JavaScript語言和DOM主宰的領域。
答案:AJAX是“Asynchronous JavaScript and XML”的縮寫。他是指一種創建交互式網頁應用的網頁開發技術。
Ajax包含下列技術:
基于web標準(standards-based presentation)XHTML+CSS的表示;
使用 DOM(Document Object Model)進行動態顯示及交互;
使用 XML 和 XSLT 進行數據交換及相關操作;
使用 XMLHttpRequest 進行異步數據查詢、檢索;
使用 JavaScript 將所有的東西綁定在一起。
為什么要用ajax:Ajax應用程序的優勢在于:
通過異步模式,提升了用戶體驗
優化了瀏覽器和服務器之間的傳輸,減少不必要的數據往返,減少了帶寬占用
Ajax引擎在客戶端運行,承擔了一部分本來由服務器承擔的工作,從而減少了大用戶量下的服務器負載。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/93535.html
摘要:獲取的對象范圍方法獲取的是最終應用在元素上的所有屬性對象即使沒有代碼,也會把默認的祖宗八代都顯示出來而只能獲取元素屬性中的樣式。因此對于一個光禿禿的元素,方法返回對象中屬性值如果有就是據我測試不同環境結果可能有差異而就是。 花了很長時間整理的前端面試資源,喜歡請大家不要吝嗇star~ 別只收藏,點個贊,點個star再走哈~ 持續更新中……,可以關注下github 項目地址 https:...
摘要:前言在阿里和騰訊工作了年,當了年的前端面試官,把期間我和我的同事常問的面試題和答案匯總在我的中。項目地址是我是小蝌蚪,騰訊高級前端工程師,跟著我一起每周攻克幾個前端技術難點。 前言 在阿里和騰訊工作了6年,當了3年的前端面試官,把期間我和我的同事常問的面試題和答案匯總在我 Github 的 Weekly-FE-Interview 中。希望對大家有所幫助。 如果你在bat面試的時候遇到了...
摘要:前言在阿里和騰訊工作了年,當了年的前端面試官,把期間我和我的同事常問的面試題和答案匯總在我的中。項目地址是我是小蝌蚪,騰訊高級前端工程師,跟著我一起每周攻克幾個前端技術難點。 前言 在阿里和騰訊工作了6年,當了3年的前端面試官,把期間我和我的同事常問的面試題和答案匯總在我 Github 的 Weekly-FE-Interview 中。希望對大家有所幫助。 如果你在bat面試的時候遇到了...
摘要:點擊訂閱云棲夜讀周刊如果說以不斷提升插件能力和可擴展能力的基礎設施開源項目民主化進程是在年的核心主題的話,那么在年,這個技術社區的發展脈絡又是怎樣的呢熱點熱議從發布,看技術社區演進方向作者技術小能手發表在阿里技術螞蟻中間件【點擊訂閱云棲夜讀周刊】 如果說以不斷提升插件能力和可擴展能力的 基礎設施開源項目民主化進程是 Kubernetes 在2017-2018年的核心主題的話,那么在2019...
摘要:這美團點評前端無痕埋點實踐前端掘金構建一個數據平臺,大體上包括數據采集數據上報數據存儲數據計算以及數據可視化展示等幾個重要的環節。 我認真起來連面試官都怕(塊級作用域,事件代理) - 掘金作者 混元霹靂手-Ziksang 如果你學完這篇文章之后,你回答完面試官之后,拿一張圖告訴面試官 在于前端面試,你給面試官講一些官方名詞,我知道react,vue,angular等等,一系列牛B的框架...
閱讀 476·2021-11-22 12:05
閱讀 1540·2021-11-17 09:33
閱讀 3584·2021-11-11 16:54
閱讀 2672·2021-10-14 09:49
閱讀 4045·2021-09-06 15:01
閱讀 1827·2019-08-29 17:23
閱讀 700·2019-08-29 14:09
閱讀 719·2019-08-29 12:28