Rumah > Soal Jawab > teks badan
Selepas Angular mengalih keluar kandungan arahan, pemantauannya masih pada $skop pengawal.
Kod adalah seperti berikut:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<p ng-app="myApp" ng-controller="myCtrl">
<p id="content">
<span-c insert="name"></span-c>
</p>
<button ng-click="del()">删除内容</button>
<button ng-click="info()">查看作用域</button>
输入内容: <input ng-model="name">
</p>
<script>
var app = angular.module('myApp', []);
app.controller('myCtrl', function ($scope, $compile) {
$scope.name = "John Doe";
$scope.$watch("xxx",function(){
console.log("xxx");
});
$scope.del = function () {
document.getElementById("content").innerHTML = "";
}
$scope.info = function () {
// $scope.$$watchers = [];
console.log($scope.$$watchers);
}
});
app.directive("spanC", spanC);
// 指令
function spanC() {
return {
restrict: "AE",
template: '',
scope:{
insert:"="
},
link: function (scope, element, attrs) {
scope.$watch("insert",function(n){
console.log("asd");
element[0].innerHTML = n;
});
}
}
}
</script>
</body>
</html>
Jika saya secara langsung
$scope.$$watchers = [];
Pakai pengawal
$scope.$watch("xxx",function(){
console.log("xxx");
});
juga telah dialih keluar Bagaimana saya boleh mengalih keluar arahan bersama dengan pemantauannya?
漂亮男人2017-05-16 13:22:19
Panggil $scope.$watch()
或 $scope.$on()
方法后,都会返回一个函数引用,用于移除监听。了解详细信息,可以查看 Angular $rootScope 官方文档。另外若想了解 $broadcast、$on、$emit
Untuk kaedah penggunaan, sila rujuk - acara angularjs $broadcast dan $emit dan $pada artikel ini.
$scope.del = function () {
document.getElementById("content").innerHTML = "";
$scope.$broadcast('destroySpan');
};
// spanC 指令link函数
link: function (scope, element, attrs) {
var unwatch = scope.$watch("insert",function(n){
console.log("asd");
element[0].innerHTML = n;
});
scope.$on('destroySpan', function() {
unwatch();
});
}
阿神2017-05-16 13:22:19
Perintah:
var clear = scope.$watch("insert",function(n){
console.log("asd");
element[0].innerHTML = n;
});
$scope.$on('$destroy', function() {
clear();
});