javascript - angularjs 中數組的修改問題
問題描述
最近在使用 angularjs 遇到一個修改數組的問題。HTML 代碼如下
<span>title1</span><span>title2</span>
js 代碼如下
$scope.title1 = '標題1'$scope.title2 = '標題2'$scope.arrTitle = [$scope.title1, $scope.title2];//我試著修改 $scope.arrTitle[0] = 'xx';
但是 $scope.title1 沒有修改?$scope.arrTitle[0] 打印過出來應該就是 $scope.title1 的啊?請問大神們指點一下,應該怎么修改才行?謝謝。
問題解答
回答1:$scope.arrTitle已經是一個新的變量了(數組)
你修改$scope.arrTitle[0],只是修改其第一個元素的數據。
$scope.arrTitle = [$scope.title1, $scope.title2];只是給數組賦初始值而已。
你希望改變$scope.arrTitle[0]時,$scope.title1也改變,那就用$scope.$watch吧
回答2:其實可以把arrTitle聲明為一個對象
<span ng-bind='arrTitle.title1'></span><span ng-bind='arrTitle.title2'></span>
$scope.arrTitle = { title1: '標題1', title2: '標題2'};//修改 $scope.arrTitle.title1 = 'xx';
相關文章:
1. javascript - jquery怎么讓a標簽跳轉后保持tab的樣式2. javascript - 請問下面代碼中的...是擴展運算符還是操作運算符?這樣寫是什么意思?3. php多任務倒計時求助4. javascript - 小demo:請教怎么做出類似于水滴不斷擴張的效果?5. css - autoprefixer沒有添加web-kit前綴6. java - spring返回json如何判斷會返回null還是empty?7. css - 如何把一個視圖放在左浮動定位的視圖的上面?8. java 中常量的定義方式。9. python的正則怎么同時匹配兩個不同結果?10. javascript - vue中怎么使用原生js插件
