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

首頁 > 編程 > JavaScript > 正文

AngularJS實踐之使用ng-repeat中$index的注意點

2019-11-19 18:18:38
字體:
來源:轉載
供稿:網友

發現問題

最近有客戶投訴,說在刪除指定的某條記錄時,結果刪掉的卻是另外一條記錄!看起來是個很嚴重的BUG。 有一次我們在工作中碰到了這個問題。 要定位這個BUG非常麻煩, 因為客戶也不清楚如何重現這個問題。

后來發現這個Bug是由于在 ng-repeat 中使用了 $index 引發的。

一個簡單動作(action)的列表

先來看看一個完整有效的ng-repeat示例。

<ul ng-controller="ListCtrl"> <li ng-repeat="item in items"> {{item.name}} <button ng-click="remove($index)">remove</button> </li></ul>

對應的控制器(controller)如下:

app.controller('ListCtrl', ['$scope', function($scope) { //items come from somewhere, from where doesn't matter for this example $scope.items = getItems(); $scope.remove = function(index) { var item = $scope.items[index]; removeItem(item); };}]);

看起來沒什么問題,對嗎? 這段代碼也沒有任何特別值得注意的。

添加一個過濾器(filter)

然后,讓我們來做一個小小的修改: 給列表添加一個過濾器。 這是很常見的做法,如果列表很長的話,例如允許用戶進行搜索。

為了方便起見, 假設我們通過 searchFilter 來查詢列表中的記錄。

<ul ng-controller="ListCtrl"> <li ng-repeat="item in items | searchFilter"> {{item.name}} <button ng-click="remove($index)">remove</button> </li></ul>

控制器的代碼保持不變。 看起來仍然沒有問題,是吧?

事實上,有一個bug藏在里面。 如果我不說, 你能找到嗎? 如果能找到,你就已經是Angular大牛了.

請盡量不要使用 $index

BUG其實是在控制器里面:

$scope.remove = function(index) { var item = $scope.items[index]; removeItem(item);};

這里使用了 index參數, 然后就遇到了BUG: 過濾后的索引(indexs)不匹配原始列表的索引。

幸運的是,有一個很簡單的方法來避免這種問題: 不要使用$index,而改成實際的item對象。

<ul ng-controller="ListCtrl"> <li ng-repeat="item in items | searchFilter"> {{item.name}} <button ng-click="remove(item)">remove</button> </li></ul>

控制器如下所示:

$scope.remove = function(item) { removeItem(item);};

注意, 這里將 remove($index) 改成 remove(item) , 并修改了 $scope.remove 函數來直接操作傳過來的對象。

這個小小的修改就完全避免了剛才的BUG。

為了更好地說明問題以及解決方案,請參考 interactive example

從中可以學到什么?

      第一個教訓當然是在使用 $index 要小心一點,因為以某些方式使用時很可能會產生BUG。

      第二個教訓是,請記住類似這樣的模式,則可以用更好的做事方式,可以完全避免某些類型的BUG。 我強烈建議大家現在不要使用 $index, 從這種簡單的思維轉變中,就可以減少代碼中的很多BUG。

      第三個教訓是測試并不是什么時候都有用。 即便有自動化測試,也覆蓋了足夠多的情形, 但對于依賴特定輸入的情況,也很容易錯過某些BUG。 錯誤本身并不是每次都會出現,即使你也用過濾來測試。

      第四個教訓是不要破壞抽象 ―― 這一點很容易被忽略。理論上 $index 是由 ng-repeat 創建的一個 “模板變量(template variable)”。 這只在 repeat 塊里面有意義(并正確起作用)。 當我們將它的值傳遞到外面時,它就失去了上下文從而不再有效。 如果確實想讓它在 repeat 之外依然有效,則必須在控制器中也進行過濾,這就需要一些不是很必要的重復代碼。 值得慶幸的是本文中介紹的模式可以用來避免這種情況。

結束語

以上就是關于AngularJS實踐之ng-repeat中$index使用注意事項的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

原文鏈接: AngularJS best practices: Be careful when using ng-repeat's $index

原文日期: 2014-11-10

翻譯日期: 2015-01-23

翻譯人員: 鐵錨 http://blog.csdn.net/renfufei

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩中文字幕精品视频| 国产亚洲精品久久久久久777| 国产精品成久久久久三级| 日韩电影免费观看在线| 日本精品一区二区三区在线播放视频| 亚洲国产精品一区二区久| 日韩欧美一区二区三区久久| 精品久久香蕉国产线看观看gif| 亚洲另类欧美自拍| 91精品国产网站| 欧洲成人性视频| 97超碰国产精品女人人人爽| 91九色综合久久| 国产午夜精品视频免费不卡69堂| 久久精品99久久香蕉国产色戒| 精品国产91久久久久久| 欧美在线视频免费| 91av在线视频观看| 亚洲精品mp4| 91精品国产91久久久久久久久| 国产成人午夜视频网址| 主播福利视频一区| 91视频九色网站| 青草成人免费视频| 日韩一区在线视频| 欧美日韩国产中字| 亚洲国产天堂久久国产91| 日韩国产中文字幕| 日韩大片在线观看视频| 国产日韩欧美另类| 精品av在线播放| 久久久人成影片一区二区三区| 国产精品jvid在线观看蜜臀| 日韩av片免费在线观看| 国产成人小视频在线观看| 日韩有码在线视频| 97涩涩爰在线观看亚洲| 日本韩国欧美精品大片卡二| 亚洲欧洲高清在线| 欧美日韩国产中文精品字幕自在自线| 国产精品男人爽免费视频1| 久久久久国产精品免费网站| 国产精品久久久久久久久粉嫩av| 国产噜噜噜噜久久久久久久久| 一本色道久久88综合日韩精品| 亚州av一区二区| 国产欧美va欧美va香蕉在| 国产xxx69麻豆国语对白| 中文字幕日韩免费视频| 国产国语刺激对白av不卡| 欧美国产日韩一区二区在线观看| 97精品视频在线观看| 亚洲精品国偷自产在线99热| 久久国产精品首页| 久久亚洲私人国产精品va| 欧美色图在线视频| 国产精品成人一区二区三区吃奶| 国产99久久精品一区二区 夜夜躁日日躁| 国产日韩换脸av一区在线观看| 日韩av电影手机在线观看| 91欧美精品成人综合在线观看| 欧美一区二区三区免费观看| 日韩高清免费在线| 欧美成人剧情片在线观看| 久久久久久网站| 精品亚洲夜色av98在线观看| 久久久久久免费精品| 在线日韩精品视频| 国产精品国产三级国产aⅴ浪潮| 成人免费观看a| 国产一区红桃视频| 国产精品久久久久久亚洲调教| 国产免费一区二区三区在线能观看| 国产精品久久久久久超碰| 欧美肥老妇视频| 国产精品老牛影院在线观看| 日韩在线视频线视频免费网站| 亚洲国产精品久久| 国产美女主播一区| 亚洲高清一区二| 亚洲精品国精品久久99热一| 国产精品成人品| 九九久久国产精品| 久久91亚洲精品中文字幕奶水| 国产精品永久免费观看| 亚洲欧美在线一区二区| 中文字幕在线亚洲| 亚洲精品在线观看www| 日韩专区在线观看| 久久久之久亚州精品露出| 亚洲成人久久一区| 亚洲男人天堂2024| 亚洲欧洲在线观看| 亚洲性无码av在线| 亚洲字幕在线观看| 国产黑人绿帽在线第一区| 欧美性在线观看| 国产美女精品视频| 国内揄拍国内精品| 欧美激情视频在线免费观看 欧美视频免费一| 26uuu国产精品视频| 亚洲国产精彩中文乱码av在线播放| 国产成人aa精品一区在线播放| 亚洲电影免费观看高清完整版在线| 亚洲一区二区中文| 国产精品免费在线免费| 精品中文字幕久久久久久| 国产精品高潮粉嫩av| 国产精品男人爽免费视频1| 国产区精品在线观看| 在线精品视频视频中文字幕| 久久精品国产欧美激情| 青青草原成人在线视频| 性欧美xxxx视频在线观看| 91国内揄拍国内精品对白| 日韩暖暖在线视频| 欧美性生交大片免网| 欧美亚洲视频在线观看| 精品久久香蕉国产线看观看亚洲| 日韩在线播放av| 欧美大片在线看| 国产+成+人+亚洲欧洲| 亚洲性69xxxbbb| 欧美精品激情视频| 欧美亚洲国产视频| 欧美壮男野外gaytube| 中文字幕亚洲国产| 久久久精品日本| 欧美成人精品在线| 性色av一区二区咪爱| 成人日韩在线电影| 欧美激情极品视频| 91亚洲精华国产精华| 国产精品入口免费视| 欧美成人精品不卡视频在线观看| 91久久精品日日躁夜夜躁国产| 国产一区二区欧美日韩| 亚洲第一视频网站| 亚洲性猛交xxxxwww| 性色av一区二区三区红粉影视| 欧洲日本亚洲国产区| 亚洲毛片在线看| 亚洲精品久久久久久久久久久| 欧美精品手机在线| 国产日韩视频在线观看| 国产男人精品视频| 亚洲国产免费av| 欧美日本在线视频中文字字幕| 日韩电影免费在线观看| 少妇高潮久久77777| 91亚洲国产成人久久精品网站| 最近2019年好看中文字幕视频| 久久精品视频在线| 久久艹在线视频| 国产精品视频公开费视频| 欧美日韩中国免费专区在线看| 亚洲国产精品人久久电影| 国产一区二区精品丝袜| 国产精品亚洲第一区| 日韩中文有码在线视频| 992tv成人免费视频| 欧美日韩成人黄色| 色悠久久久久综合先锋影音下载| 欧美有码在线视频|