国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jquery操作angularjs對象

2019-11-20 12:08:31
字體:
來源:轉載
供稿:網友

jquery是一個非常強大的js框架,angularjs是一個非常牛的前端mvc框架。雖然用其中的任何一個框架在項目中夠用了,但是有時候這兩個框架需要混合著用,雖然不推薦。但有時候混合用時,卻非常方便,不要考慮那么多,只要能實現功能,何樂而不為?

  最近做的一個產品,前端用angularjs,但表格框架用的卻是jquery.datatables.js,當然其中少不了碰到jquery與angularjs交互問題。由于公司保密,我就不用真實項目演示了,寫個小demo吧,當然真實的項目要復雜得多。

<!DOCTYPE html><html ng-app="ngDemo"><head>  <title></title>  <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script>  <script src="http://www.w3cschool.cc/try/angularjs/1.2.5/angular.min.js"></script>  <script type="text/javascript">  $(function() {    $('#btn').on('click',function(e) {      $('#dv2').text(Number($('#dv2').text())+1);//jquery+angular實現      $('#dv3').text(Number($('#dv3').text())+1);//純jquery實現    });  });    var app=angular.module('ngDemo',[]);  app.controller('ngCtrl',['$scope',function ($scope) {    $scope.test1=0;    $scope.test2=0;  }]);  </script></head><body ng-controller="ngCtrl">test1:<div id="dv1">{{test1}}</div><!--純angular實現-->test2:<div id="dv2" ng-bind="test2" ng-model="test2"></div>test3:<div id="dv3">0</div><button id="btn" ng-click="test1=test1+1">click me +1</button></body></html>

代碼

效果

點了兩次,這三個值都加到2了,貌似沒什么問題。

真沒問題嗎?請看

視圖上是2,model上還是0,沒有實現同步,怎么辦?

那么問題又來了,jquery和angularjs哪家強呢?

改下代碼

$('#btn').on('click',function(e) {      var scope=angular.element('#dv2').scope();//jquery+angular實現      scope.test2=scope.test2+1;//直接修改test2的值      console.log(scope.test2);      $('#dv3').text(Number($('#dv3').text())+1);//純jquery實現    });

再看看

點了兩次,中間那個變成了1,其它兩個是2。

點了3次,中間那個變成了2,但是scope.test2的值卻是什么,它怎么總是顯示慢一拍?

再改改

$('#btn').on('click',function(e) {      var scope=angular.element('#dv2').scope();//jquery+angular實現      scope.test2=scope.test2+1;//直接修改test2的值      scope.$apply();//綁定到視圖      console.log(scope.test2);      $('#dv3').text(Number($('#dv3').text())+1);//純jquery實現    });

再看看

這下這三個都同步了。中藥好,西藥快,中本結合!jquery簡單,angularjs方便,兩者結合...大功告成。

注意:scope對象一定要調用$apply(),否則會出現視圖與model不同步。

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 合山市| 江都市| 尼木县| 辉县市| 桐乡市| 博兴县| 内乡县| 息烽县| 和静县| 东丽区| 彭水| 积石山| 曲麻莱县| 静安区| 苍梧县| 大石桥市| 同德县| 伊吾县| 灵璧县| 板桥市| 南雄市| 平乡县| 丹江口市| 永宁县| 阜康市| 鲁甸县| 阿拉尔市| 陈巴尔虎旗| 叙永县| 左贡县| 三亚市| 永定县| 偏关县| 迁安市| 麟游县| 桐城市| 芒康县| 丹巴县| 定结县| 随州市| 贵州省|