當(dāng)前位置:
首頁(yè) >
前端技术
> javascript
>内容正文
javascript
深究AngularJS——ng-checked(回写:带真实案例代码)
生活随笔
收集整理的這篇文章主要介紹了
深究AngularJS——ng-checked(回写:带真实案例代码)
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1.需求
在添加頁(yè)面實(shí)現(xiàn)一個(gè)checkbox的選擇,然后在詳情頁(yè)面展示時(shí),會(huì)自動(dòng)選上之前被選中的。
2.添加頁(yè)面
看官最好將這個(gè)代碼復(fù)制過(guò)去看看效果。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <div ng-app="myApp" ng-controller="myCtrl" >選擇<div ng-repeat="item in list"><input type="checkbox" name="tagName" value="item.id" ng-click="select(item.id,$event)"> {{item.shortName}}</div>結(jié)果:{{result}} </div> <script> var app = angular.module('myApp', []);app.controller('myCtrl', function($scope) {//創(chuàng)建checkbox用的$scope.list=[{"id":1,"shortName":"張三"},{"id":2,"shortName":"李四"},{"id":3,"shortName":"王二"}];//存儲(chǔ)已選$scope.result = [];//觸發(fā)事件$scope.select = function(id,event){ console.log(event)//打印看看這是什么,有利于理解console.log(action)var action = event.target;if(action.checked){//選中,就添加if($scope.result.indexOf(id) == -1){//不存在就添加$scope.result.push(id);}}else{//去除就刪除result里var idx = $scope.result.indexOf(id);if( idx != -1){//不存在就添加$scope.result.splice(idx,1);}}};}); </script> </body> </html>3.詳情展示
//假設(shè)添加頁(yè)面的結(jié)果是:$scope.result = [3,2];
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body><div ng-app="myApp" ng-controller="myCtrl" >回寫時(shí)設(shè)置不可選,即設(shè)ng-disabled="true"<div ng-repeat="item in list"><input type="checkbox" name="tagName" ng-checked="isSelected(item.id)" value="item.id" ng-disabled="true" > {{item.shortName}}</div>結(jié)果:{{result}} </div><script> var app = angular.module('myApp', []);app.controller('myCtrl', function($scope) {//創(chuàng)建checkbox用的$scope.list=[{"id":1,"shortName":"張三"},{"id":2,"shortName":"李四"},{"id":3,"shortName":"王二"}];//在添加頁(yè)面得到的結(jié)果//你會(huì)發(fā)現(xiàn),順序也不會(huì)影響結(jié)果$scope.result = [3,2];//被選中條件:ng-checked的結(jié)果為true$scope.isSelected = function(id){ return $scope.result.indexOf(id)!=-1; //只要返回的結(jié)果為true,則對(duì)應(yīng)的checkbox就會(huì)被選中,//所以我的思路是看存添加頁(yè)面的結(jié)果里是否含有當(dāng)前id即value值,//有就返回的true,沒(méi)有就返回false};}); </script> </body> </html> 《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的深究AngularJS——ng-checked(回写:带真实案例代码)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 深究AngularJS——下拉框(sel
- 下一篇: 深究AngularJS——校验(非for