jquery操作angularjs對象
jquery是一個非常強(qiáng)大的js框架,angularjs是一個非常牛的前端mvc框架。雖然用其中的任何一個框架在項目中夠用了,但是有時候這兩個框架需要混合著用,雖然不推薦。但有時候混合用時,卻非常方便,不要考慮那么多,只要能實現(xiàn)功能,何樂而不為?
最近做的一個產(chǎn)品,前端用angularjs,但表格框架用的卻是jquery.datatables.js,當(dāng)然其中少不了碰到j(luò)query與angularjs交互問題。由于公司保密,我就不用真實項目演示了,寫個小demo吧,當(dā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實現(xiàn)
$('#dv3').text(Number($('#dv3').text())+1);//純jquery實現(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實現(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>
代碼

效果

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

視圖上是2,model上還是0,沒有實現(xiàn)同步,怎么辦?
那么問題又來了,jquery和angularjs哪家強(qiáng)呢?
改下代碼
$('#btn').on('click',function(e) {
var scope=angular.element('#dv2').scope();//jquery+angular實現(xiàn)
scope.test2=scope.test2+1;//直接修改test2的值
console.log(scope.test2);
$('#dv3').text(Number($('#dv3').text())+1);//純jquery實現(xiàn)
});
再看看

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

點了3次,中間那個變成了2,但是scope.test2的值卻是什么,它怎么總是顯示慢一拍?
再改改
$('#btn').on('click',function(e) {
var scope=angular.element('#dv2').scope();//jquery+angular實現(xiàn)
scope.test2=scope.test2+1;//直接修改test2的值
scope.$apply();//綁定到視圖
console.log(scope.test2);
$('#dv3').text(Number($('#dv3').text())+1);//純jquery實現(xiàn)
});
再看看

這下這三個都同步了。中藥好,西藥快,中本結(jié)合!jquery簡單,angularjs方便,兩者結(jié)合...大功告成。
注意:scope對象一定要調(diào)用$apply(),否則會出現(xiàn)視圖與model不同步。
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
相關(guān)文章
Ubuntu系統(tǒng)下Angularjs開發(fā)環(huán)境安裝
本文主要介紹 Ubuntu系統(tǒng)下Angularjs開發(fā)環(huán)境安裝,這里詳細(xì)介紹了安裝步驟和注意事項,有在Ubuntu 環(huán)境下開發(fā)的朋友可以參考下2016-09-09
AngularJS基礎(chǔ) ng-srcset 指令簡單示例
本文主要介紹AngularJS ng-srcset 指令,這里對ng-srcset 指令做了詳細(xì)的資料整理,附有代碼示例,有需要的小伙伴可以參考下2016-08-08
仿Angular Bootstrap TimePicker創(chuàng)建分鐘數(shù)-秒數(shù)的輸入控件
這篇文章主要為大家詳細(xì)介紹了仿Angular Bootstrap TimePicker創(chuàng)建分鐘數(shù)-秒數(shù)的輸入控件的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-07-07
angularjs 的數(shù)據(jù)綁定實現(xiàn)原理
本篇文章主要介紹了angularjs 的數(shù)據(jù)綁定實現(xiàn)原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07

