亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

jquery操作angularjs對象

 更新時(shí)間:2015年06月26日 11:53:01   投稿:hebedich  
這篇文章主要介紹了jquery操作angularjs對象的相關(guān)資料,需要的朋友可以參考下

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

  最近做的一個(gè)產(chǎn)品,前端用angularjs,但表格框架用的卻是jquery.datatables.js,當(dāng)然其中少不了碰到j(luò)query與angularjs交互問題。由于公司保密,我就不用真實(shí)項(xiàng)目演示了,寫個(gè)小demo吧,當(dāng)然真實(shí)的項(xiàng)目要復(fù)雜得多。

<!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實(shí)現(xiàn)
      $('#dv3').text(Number($('#dv3').text())+1);//純jquery實(shí)現(xiàn)
    });
  });
  
  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實(shí)現(xiàn)-->
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>

代碼

效果

點(diǎn)了兩次,這三個(gè)值都加到2了,貌似沒什么問題。

真沒問題嗎?請看

視圖上是2,model上還是0,沒有實(shí)現(xiàn)同步,怎么辦?

那么問題又來了,jquery和angularjs哪家強(qiáng)呢?

改下代碼

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

再看看

點(diǎn)了兩次,中間那個(gè)變成了1,其它兩個(gè)是2。

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

再改改

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

再看看

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

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

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

相關(guān)文章

最新評(píng)論