angular1.x,dom操作与ng数据操作的冲突问题

阅读 2.4k
1 个回答

先说明原因

  • 1:dom操作,直接改变的View值,但是$scope.name还是123,没有改变,这点很重要

  • 2:ng操作,因为$scope.name还是123,这个时候赋值123,实际上什么都没干

  • 3:ng操作,$scope.name赋值124,这个时候name改变了,angular回去更新view的值,因为值是一样的所以看不出来效果。再点击2:ng操作,$scope.name赋值123,改变了会同步更新view的值。

有点绕

补充

var helloApp = angular.module("helloApp", []);
helloApp.controller("HelloCtrl", function($scope) {
  $scope.name = "123";  
  
  $('#domopr').click(function(){
    $scope.$apply(function(){
       $scope.name = "124";
    });
  });
});
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进