Jquery和angularjs獲取check框選中的值小技巧
首先看一下html程式碼:
1 <!DOCTYPE html> 2 <html data-ng-app="App"> 3 <head> 4 <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.8/angular.min.js"></script> 5 <script src="script2.js"></script> 6 </head> 7 <body data-ng-controller="AddStyleCtrl"> 8 9 <div>Choose Tags</div> 10 <div> 11 <div>You have choosen:</div> 12 <hr> 13 <label data-ng-repeat="selectedTag in selectedTags"> 14 (({{selectedTag}})) 15 </label> 16 <hr> 17 <div data-ng-repeat="category in tagcategories"> 18 <div>{{ category.name }}</div> 19 <div data-ng-repeat="tag in category.tags"> 20 <div> 21 <input type="checkbox" id={{tag.id}} name="{{tag.name}}" ng-checked="isSelected(tag.id)" ng-click="updateSelection($event,tag.id)"> 22 {{ tag.name }} 23 </div> 24 </div> 25 <hr> 26 </div> 27 </div> 28 29 <pre>{{selected|json}}</pre> 30 <pre>{{selectedTags|json}}</pre> 31 32 </body> 33 </html>
line2 定義了AngularJS App;
line4 引入angularjs指令碼;
line5 引入自己寫的script2.js指令碼;
line7 指定控制器AddStyleCtrl
line13-15 實時顯示已選標籤給使用者看;
line17-line26 使用雙重迴圈列出資料庫(本例中就儲存在了controller的一個物件裡)中的資料;
line21的這行程式碼作用可大了:<inputtype="checkbox" id={{tag.id}}name="{{tag.name}}" ng-checked="isSelected(tag.id)" ng-click="updateSelection($event,tag.id)">
儲存了tag的id,name,利用isSelected(tag.id)來判斷是否被checked,點選時候呼叫updateSelection($event,tag.id)方法;
如果想 ng-click 觸發的函式裡獲取到該觸發該函式的元素不能直接傳入 this ,而需要傳入event。因為在Angularjs裡面,這個地方的this是 scope 。我們可以傳入 event,然後在函數裡面通過 event.target 來獲取到該元素。
line29-30 是測試時候給自己看的,可以看到selected陣列和selectedTags陣列中的內容;
然後看看AngularJS程式碼:(script2.js)
1 /**
2 * Created by zh on 20/05/15.
3 */
4 // Code goes here
5
6 var iApp = angular.module("App", []);
7
8
9
10 iApp.controller('AddStyleCtrl', function($scope)
11 {
12 $scope.tagcategories = [
13 {
14 id: 1,
15 name: 'Color',
16 tags: [
17 {
18 id:1,
19 name:'color1'
20 },
21 {
22 id:2,
23 name:'color2'
24 },
25 {
26 id:3,
27 name:'color3'
28 },
29 {
30 id:4,
31 name:'color4'
32 },
33 ]
34 },
35 {
36 id:2,
37 name:'Cat',
38 tags:[
39 {
40 id:5,
41 name:'cat1'
42 },
43 {
44 id:6,
45 name:'cat2'
46 },
47 ]
48 },
49 {
50 id:3,
51 name:'Scenario',
52 tags:[
53 {
54 id:7,
55 name:'Home'
56 },
57 {
58 id:8,
59 name:'Work'
60 },
61 ]
62 }
63 ];
64
65 $scope.selected = [];
66 $scope.selectedTags = [];
67
68 var updateSelected = function(action,id,name){
69 if(action == 'add' && $scope.selected.indexOf(id) == -1){
70 $scope.selected.push(id);
71 $scope.selectedTags.push(name);
72 }
73 if(action == 'remove' && $scope.selected.indexOf(id)!=-1){
74 var idx = $scope.selected.indexOf(id);
75 $scope.selected.splice(idx,1);
76 $scope.selectedTags.splice(idx,1);
77 }
78 }
79
80 $scope.updateSelection = function($event, id){
81 var checkbox = $event.target;
82 var action = (checkbox.checked?'add':'remove');
83 updateSelected(action,id,checkbox.name);
84 }
85
86 $scope.isSelected = function(id){
87 return $scope.selected.indexOf(id)>=0;
88 }
89 });
點選行的時候選中check框:
先再行上新增一個點選事件,把這個行個傳到後臺:
ng-click="checkTr(this)"
接著給當前單元格的check框賦值;
<td class="text-center"><label> <input type="radio" ng-model="check" value="{{e.docGuid}}" name="check"> </label></td>
$scope.checkTr=function(tr){
$scope.check=tr.e.docGuid;
};
自定義複選框對應的值
預設情況下,繫結到複選框上的值是ture或者false。有時候,我們希望返回的其它值。Angular提供了一種非常好的處理方式:使用ng-ture-value和ng-false-value。
我們新增另外一組複選框,不過這時侯我們使用的不再是true或者false,而是使用者自定義的值。
<!-- CUSTOM VALUE CHECKBOXES -->
<label>Personal Question</label>
<div class="checkbox">
<label>
<input type="checkbox" name="awesome" ng-model="formData.awesome" ng-true-value="ofCourse" ng-false-value="iWish">
Are you awesome?
</label>
</div>
Angularjs全選全不選: