亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

angularJS開發注意事項

2019-11-19 13:46:43
字體:
來源:轉載
供稿:網友

作為一個coder,應該具有經??偨Y反思的習慣,如果不能及時總結,可能就會忘記自己踩過的很多坑,然后會導致同一個坑踩很多次,所以我打算把這些都記錄下來,以方便是對自己的重復記憶,避免無效的coding,另一方面可以希望可以給遇到相似問題的同僚們一些收獲.

1.手動觸發臟檢查

在開發過程中,我們可能經常會通過js來手動更改綁定的相關數據,而不是通過dom操作來改變綁定的相關數據,這樣也很多情況下會導致綁定數據的視圖不能夠及時更新,這個時候就需要我們手動觸發一下臟檢查,下面我就介紹一下三種手動觸發臟檢查的方法.

(1) apply()方法在需要手動觸發的地方調用scope.apply(),使用該方法會觸發angular從rootScope的作用域下開始進行綁定變量值的輪詢,相比較digest()方法比較費時.

但是這個有時這個方法會報錯.

(2) digest()方法在需要手動觸發的地方調用scope.digest(),使用該方法會觸發angular從scope的作用域下開始進行綁定變量值的輪詢,相比較aplly()更合理.

(3) timeout()方法將操作綁定數據的邏輯寫在timeout()方法中.

找到一種更完美的解決動態添加數據導致頁面不能及時渲染的方法,迫不及待地來分享給大家~~~

可以定義一個全局的方法.這個方法就是經過處理過的apply函數,大家都叫它safeApply.上代碼了:

$rootScope.safeApply = function(fn) {  var phase = this.$root.$$phase;  if(phase == '$apply' || phase == '$digest') {    if(fn && (typeof(fn) === 'function')) {      fn();    } else {      this.$apply(fn);    }  }}

然后在需要動態添加吧的地方調用rootScope.safeApply()即可,或者把需要動態添加的代碼作為寫進rootScope.safeApply方法的fn參數里.

2.ng-model-options 指令

這個指令在表單校驗的時候非常有用,我們可以設置什么時候出發試圖更新,這樣你就可以設置dom元素失去焦點改變后調用監聽,從而顯示校驗的提示. <input>, <select>, <textarea>,這些元素支持該指令

<input ng-model="name" ng-model-options="{updateOn: 'blur'}"> //使用示例

//可配置參數

{updateOn: 'event'}規則指定事件發生后綁定數據
{debounce : 1000} 規定等待多少毫秒后綁定數據
{allowInvalid : true|false} 規定是否需要驗證后綁定數據
{getterSetter : true|false} 規定是否作為 getters/setters 綁定到模型
{timezone : '0100'} 規則是否使用時區

3. 告別令人尷尬的 {{}}

我們都知道,當頁面還未加載完畢的時候會出現{{ xxx }}這種尷尬的情況,通過使用ng-bind-template指令,就可以避免尷尬情況的出現.

<p ng-bind-template="{{name}}"></p>   //使用示例

4.解決ng-if,ng-show,ng-hide偶然出現的閃現的問題

(1) 將html片段抽出,通過指令引入ng-include,ng-bind-html

(2) 通過ng-cloak指令

5.控制器之間的通訊問題

(1)路由傳參

//傳遞$state.go(path, {name:"dfdd"})ui-sref="path({name:"dfdd"})"http://獲取$scope.$stateParams.name

(2)通過廣播

通過子元素傳遞給父元素,然后父元素再廣播給其他子元素,注意這個廣播是很快就完成的,所以很有可能出現子頁面還未加載完父元素的廣播就已經完成了,為了避免這種情況,需要父元素的廣播延遲執行.
(這種情況有一個弊端,當進入子頁面后再次刷新頁面,這次的廣播已經沒有了,就會導致這個子頁面的數據獲取失敗了.)

(3)定義全局變量(window)

將多個控制器都需要通訊的變量定義為全局的.這樣每個控制器都可以訪問到和改寫.

(4) 緩存

sessionStorage, localStorage, cookie,瀏覽器的各種數據庫

以上方法個人比較推薦路由傳參的方式

6.$destroy的使用是必要的

  • (1)頁面離開時清除頁面的定時器
  • (2)頁面離開時清除頁面的監聽器
  • (3)頁面離開時清除頁面的modal,popover之類的遮罩層.
var destroyWatcher = $scope.$watch(...);//示例代碼//$watch方法會返回一個函數,這個函數用來銷毀監聽器,我們用一個變量承接這個函數,然后再destory的時候調用這個函數就可以銷毀不必要的監聽器了.$scope.$on("$destroy", function() {  if (timer) {     $timeout.cancel(timer);   }   $scope.popover.remove();  destroyWatcher();}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区三区在线免费观看| 伊人成人开心激情综合网| 国产在线视频一区| 亚洲最大福利网| 国产精品爱啪在线线免费观看| 国产精品揄拍500视频| 亚洲缚视频在线观看| 欧美成人免费一级人片100| 欧美一级淫片videoshd| 国产香蕉精品视频一区二区三区| 欧美刺激性大交免费视频| 91香蕉嫩草影院入口| 精品女同一区二区三区在线播放| 九九热这里只有精品6| 亚洲国产高潮在线观看| 亚洲精品网址在线观看| 久久精品视频在线观看| 欧美激情精品久久久久久黑人| 国产一区二区三区免费视频| 国产成人精品久久久| 成人免费激情视频| 最新69国产成人精品视频免费| 欧美噜噜久久久xxx| 日韩网站在线观看| 久久青草精品视频免费观看| 欧美高清性猛交| 国产精品丝袜白浆摸在线| 最近更新的2019中文字幕| 国产精品久久久久久久久久久久| 日韩在线高清视频| 亚洲精品久久久久国产| 韩国精品美女www爽爽爽视频| 久久精品久久久久久国产 免费| 一区二区av在线| 8050国产精品久久久久久| 91欧美激情另类亚洲| 成人亚洲综合色就1024| 欧美与黑人午夜性猛交久久久| 日韩av在线高清| 国产精品美女主播| 国产精品久久97| 亚洲va码欧洲m码| 日韩美女激情视频| 日本精品久久久久久久| 久久人91精品久久久久久不卡| 亚洲精品久久久久中文字幕二区| 欧美激情精品久久久久久免费印度| 成人免费视频网址| 狠狠躁夜夜躁久久躁别揉| 欧美国产日韩一区二区三区| 亚洲成人久久久久| 中文字幕久精品免费视频| 欧美成人性色生活仑片| 奇门遁甲1982国语版免费观看高清| 亚洲最大av在线| 国产日韩中文字幕在线| 欧美裸体xxxx极品少妇| 日本精品久久电影| 91热精品视频| 上原亚衣av一区二区三区| 久久久久国产视频| 日韩视频永久免费观看| y97精品国产97久久久久久| 欧美成人国产va精品日本一级| 欧美一性一乱一交一视频| 亚洲激情视频在线播放| 91精品久久久久久久久久久| 欧美激情久久久久久| 人妖精品videosex性欧美| 亚洲国产高潮在线观看| 欧美成人黑人xx视频免费观看| 亚洲欧美另类在线观看| 日韩欧美黄色动漫| 一区二区三区美女xx视频| 久久久国产精品视频| 91免费人成网站在线观看18| 亚洲精品成a人在线观看| 欧美夫妻性生活视频| 国产日韩专区在线| 亚洲自拍欧美另类| 日韩一区av在线| 色综合老司机第九色激情| 亚洲国产另类 国产精品国产免费| 亚洲欧美在线第一页| 国产专区欧美专区| 91精品国产91久久久| 97视频在线观看视频免费视频| 韩国精品美女www爽爽爽视频| 欧美美女操人视频| 一区二区三区亚洲| 国产视频福利一区| 亚洲第一页中文字幕| 国产精品免费观看在线| 欧美一区二区三区四区在线| 亚洲精品在线视频| 国产伊人精品在线| 欧美专区在线视频| 亚洲第一精品自拍| 日韩成人小视频| 亚洲高清不卡av| 久久精品国产一区| 欧美亚洲另类视频| 亚洲国产精品999| 国语自产精品视频在免费| 欧美在线亚洲在线| 国产日韩精品综合网站| 色老头一区二区三区在线观看| 国产午夜精品一区理论片飘花| 色婷婷久久一区二区| 久色乳综合思思在线视频| 亚洲成色www8888| 福利一区福利二区微拍刺激| 国产激情综合五月久久| 欧美片一区二区三区| 亚洲天堂第二页| 欧美成人免费小视频| 中文字幕日韩欧美精品在线观看| 色无极亚洲影院| 国产视频精品xxxx| 久久久中文字幕| 丝袜亚洲另类欧美重口| 中文字幕亚洲第一| 欧美日韩一区免费| 久久久亚洲福利精品午夜| 欧美在线一区二区三区四| 久久久精品免费视频| 日韩精品视频免费专区在线播放| 国产精品丝袜久久久久久高清| 国产精品第100页| 中文字幕日韩在线观看| 欧美视频专区一二在线观看| 97超碰蝌蚪网人人做人人爽| 69视频在线免费观看| 成人在线视频福利| 韩剧1988在线观看免费完整版| 亚洲精品在线看| 欧美激情三级免费| 久久久久女教师免费一区| 久久精品国产久精国产一老狼| 国产精品专区h在线观看| 国产精品7m视频| 色噜噜狠狠狠综合曰曰曰88av| 91亚洲午夜在线| 中文字幕亚洲一区在线观看| 欧美亚洲午夜视频在线观看| 一本一道久久a久久精品逆3p| 国产精品久久久久久久久男| 亚洲午夜精品久久久久久性色| 美日韩精品免费视频| 中文字幕在线观看日韩| 欧美激情免费在线| 69久久夜色精品国产69| 久久精品视频免费播放| 在线播放国产一区中文字幕剧情欧美| 日韩欧美在线免费观看| 欧美做受高潮电影o| 亚洲天堂av在线播放| 欧美精品精品精品精品免费| 欧美高清视频一区二区| 精品国产欧美一区二区三区成人| 欧美精品videos另类日本| 亚洲а∨天堂久久精品喷水| 久久久亚洲天堂| 日日噜噜噜夜夜爽亚洲精品|