搜索

首页  >  问答  >  正文

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

http://codepen.io/anon/pen/JXogBj?editors=1010

如上面的代码所示,
点击1:dom操作再点击2:ng操作,标签的值没改,除非点击3:ng操作再点击2:ng操作
有什么方法可以让2:ng操作总是生效?

仅有的幸福仅有的幸福2779 天前737

全部回复(1)我来回复

  • 怪我咯

    怪我咯2017-05-15 17:01:06

    先说明原因

    • 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";
        });
      });
    });

    回复
    0
  • 取消回复