色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

angular.js - 請問ng-click="alterCheck()"和ng-click="check=true"有什么不同?

瀏覽:126日期:2024-10-01 10:33:22

問題描述

<section ng-app='app' ng-controller='ctrl'> <p ng-show='check && form.$invalid'></p> <form name='form' ng-submit='init()'> <input type='text' ng-model='text' required/> <!-- <input type='submit' ng-click='alterCheck()'/> --> <input type='submit' ng-click='check=true'/> </form></section>angular.module(’app’, []).controller(’ctrl’, function($scope){ $scope.check = false; $scope.init2 = function() { $scope.text = ’’; } $scope.init = function() { $scope.init2(); $scope.check = false; } $scope.alterCheck = function() { $scope.check = true; }})

在實際項目中,使用 ng-click='check=true' 的方法會造成點擊后 p 處于顯示的狀態(tài),而 ng-click='alterCheck()' 則不會,請問這是什么原因呢?上述代碼無法復現(xiàn)我所說的現(xiàn)象。有什么額外的原因可能造成這一現(xiàn)象嗎?

問題解答

回答1:

我在這個例子里可以重現(xiàn)類似你描述的問題(因為之前遇到過,所以多看了幾眼):

<p ng-controller='DemoCtrl'> <ul> <li ng-repeat='item in items'> <input type='radio' name='group' ng-model='item.checked' ng-click='checkIndex = $index'>{{ item.name }} <!-- <input type='radio' name='group' ng-model='item.checked' ng-click='changeCheckIndex($index)'>{{ item.name }} --> </li> </ul> checkIndex: {{ checkIndex }}</p>

var demo = angular.module(’myApp’, []);demo.controller(’DemoCtrl’, function($scope, $timeout){ $scope.checkIndex = 0;$scope.changeCheckIndex = function(index){$scope.checkIndex = index; };$scope.items = [{name: ’Beijing’,checked: false },{name: ’Shanghai’,checked: false },{name: ’Taiyuan’,checked: false }];});

這是一個很簡單的demo,通過ng-repeat顯示一組單選框,通過點擊點選按鈕,在下面的checkIndex: {{ checkIndex }}中顯示選中的單選框的$index。在線demo看這里:jsfiddle

如果運行當前的代碼,會發(fā)現(xiàn),{{ checkIndex }}壓根沒有變化,無論你怎么使勁點,戳破鼠標也沒用

但如果template換成我注釋掉的那部分代碼,改用changeCheckIndex方法,{{ checkIndex }}就變化了。

那么問題來了,如何造成這個局面的?我們還是要回到文檔去(最近發(fā)現(xiàn)ng的文檔還是不錯的):

angular.js - 請問ng-click="alterCheck()"和ng-click="check=true"有什么不同?

我認為原因在于checkIndex = $index的寫法,使得checkIndex是一個在每個template instance中獨立$scope下的變量,并不是我們在Controller里定義的那個。

文檔地址: ngRepeat

回答2:

值的復制和對象的引用的區(qū)別,這個問題不好回答啊,重現(xiàn)不了錯誤,只能大概覺得。

相關(guān)文章:
主站蜘蛛池模板: 午夜精品影院 | 欧美一区视频 | 欧美成人香蕉网在线观看 | 深夜福利视频在线看免费 | 日韩中文字幕在线亚洲一区 | 亚洲精品影院一区二区 | a级毛片免费在线观看 | 在线观看亚洲精品专区 | 国产精品高清视亚洲精品 | 久久99国产精品久久99果冻传媒 | 日本a级特黄三级三级三级 日本a一级片 | 久久成人动漫 | 国产一区免费观看 | 亚洲国产精品视频 | 一级特级毛片免费 | 国产精品亚洲二区 | 免费福利入口在线观看 | 久久国内精品自在自线400部o | 自拍在线| 91九色视频无限观看免费 | 成年人在线视频 | 免费人成激情视频在线观看冫 | 国产理论最新国产精品视频 | 99热久久免费精品首页 | 色噜噜国产精品视频一区二区 | 成人性版蝴蝶影院污 | 在线观看日本亚洲一区 | 国产成人在线网址 | 精品99久久 | 透逼视频 | 中文字幕成人 | 国产成人精品一区二区秒拍 | 99国产精品视频久久久久 | 99精彩视频| 91久久精品 | 日韩精品亚洲人成在线观看 | 欧美日韩中文一区二区三区 | 亚洲欧美久久 | 日本a级特黄三级三级三级 日本a一级片 | 男女配种猛烈免费视频 | 国产精品亚洲片在线不卡 |