W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
這個(gè)問題似乎很多人都關(guān)心,但是事實(shí)是,如果了解了 ng 的工作方式,這本來就不是一個(gè)問題了。
在我自己使用 ng 的過程當(dāng)中,一直是混用 jQuery 的,以前還要加上一個(gè) Dojo 。只要了解每種框架的工作方式,在具體的代碼中每個(gè)框架都做了什么事,那么整體上控制起來就不會(huì)有問題。
回到 ng 上來看,首先對(duì)于 jQuery 來說,最開始說提到過,在 DOM 操作部分, ng 與 jQuery 是兼容的,如果沒有 jQuery , ng 自己也實(shí)現(xiàn)了兼容的部分 API 。
同時(shí),最開始也提到過, ng 的使用最忌諱的一點(diǎn)就是修改 DOM 結(jié)構(gòu)——你應(yīng)該使用 ng 的模板機(jī)制進(jìn)行數(shù)據(jù)綁定,以此來控制 DOM 結(jié)構(gòu),而不是直接操作。換句話來說,在不動(dòng) DOM 結(jié)構(gòu)的這個(gè)前提之下,你的數(shù)據(jù)隨便怎么改,隨便使用哪個(gè)框架來控制都是沒問題的,到時(shí)如有必要使用 $scope.$digest() 來通知 ng 一下即可。
下面這個(gè)例子,我們使用了 jQuery 中的 Deferred ( $.ajax 就是返回一個(gè) Deferred ),還使用了 ng 的 $timeout ,當(dāng)然是在 ng 的結(jié)構(gòu)之下:
<!DOCTYPE html> <html ng-app="Demo"> <head> <meta charset="utf-8" /> <title>AngularJS</title> </head> <body> <div ng-controller="TestCtrl"> <span ng-click="go()">{{ a }}</span> </div> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js" rel="external nofollow" rel="external nofollow" > </script> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.3/angular.min.js" rel="external nofollow" rel="external nofollow" > </script> <script type="text/javascript"> var app = angular.module('Demo', [], angular.noop); app.controller('TestCtrl', function($scope, $timeout){ $scope.a = '點(diǎn)擊我開始'; var defer = $.Deferred(); var f = function(){ if($scope.a == ''){$scope.a = '已停止'; return} defer.done(function(){ $scope.a.length < 10 ? $scope.a += '>' : $scope.a = '>'; $timeout(f, 100); }); } defer.done(function(){$scope.a = '>'; f()}); $scope.go = function(){ defer.resolve(); $timeout(function(){$scope.a = ''}, 5000); } }); </script> </body> </html>
再把 Dojo 加進(jìn)來看與 DOM 結(jié)構(gòu)相關(guān)的例子。之前說過,使用 ng 就最好不要手動(dòng)修改 DOM 結(jié)構(gòu),但這里說兩點(diǎn):
下面這個(gè)例子使用了 AngularJS , jQuery , Dojo :
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>AngularJS</title> <link rel="stylesheet" rel="external nofollow" target="_blank" media="screen" /> </head> <body class="claro"> <div ng-controller="TestCtrl" id="test_ctrl"> <p ng-show="!btn_disable"> <button ng-click="change()">調(diào)用dojo修改按鈕</button> </p> <p id="btn_wrapper"> <button data-dojo-type="dijit/form/Button" type="button">{{ a }}</button> </p> <p> <input ng-model="dialog_text" ng-init="dialog_text='對(duì)話框內(nèi)容'" /> <button ng-click="dialog(dialog_text)">顯示對(duì)話框</button> </p> <p ng-show="show_edit_text" style="display: none;"> <span>需要編輯的內(nèi)容:</span> <input ng-model="text" /> </p> <div id="editor_wrapper"> <div data-dojo-type="dijit/Editor" id="editor"></div> </div> </div> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/dojo/1.9.1/dojo/dojo.js" rel="external nofollow" > </script> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js" rel="external nofollow" rel="external nofollow" > </script> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.3/angular.min.js" rel="external nofollow" rel="external nofollow" > </script> <script type="text/javascript"> require(['dojo/parser', 'dijit/Editor'], function(parser){ parser.parse($('#editor_wrapper')[0]).then(function(){ var app = angular.module('Demo', [], angular.noop); app.controller('TestCtrl', function($scope, $timeout){ $scope.a = '我是ng, 也是dojo'; $scope.show_edit_text = true; $scope.change = function(){ $scope.a = 'DOM結(jié)構(gòu)已經(jīng)改變(不建議這樣做)'; require(['dojo/parser', 'dijit/form/Button', 'dojo/domReady!'], function(parser){ parser.parse($('#btn_wrapper')[0]); $scope.btn_disable = true; } ); } $scope.dialog = function(text){ require(["dijit/Dialog", "dojo/domReady!"], function(Dialog){ var dialog = new Dialog({ title: "對(duì)話框哦", content: text, style: "width: 300px" }); dialog.show(); }); } require(['dijit/registry'], function(registry){ var editor = registry.byId('editor'); $scope.$watch('text', function(new_v){ editor.setValue(new_v); }); }); }); angular.bootstrap(document, ['Demo']); }); }); </script> </body> </html>
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: