angularjs – ng-list中的可内容项目的双向绑定
发布时间:2020-12-17 07:39:24 所属栏目:安全 来源:网络整理
导读:我正在寻找使用contenteditable属性更新手机列表中的电话名称.我已经尝试使用ng-change,但是没有被解雇.有什么办法可以做到吗? 我有一个Store.Phones的列表 ul class="store" li ng-repeat="Phone in Store.Phones" strong contenteditable {{Phone.Name}}/
|
我正在寻找使用contenteditable属性更新手机列表中的电话名称.我已经尝试使用ng-change,但是没有被解雇.有什么办法可以做到吗?
我有一个Store.Phones的列表 <ul class="store">
<li ng-repeat="Phone in Store.Phones">
<strong contenteditable> {{Phone.Name}}</strong>
</li>
<ul>
所以现在当我编辑电话名称我需要在列表中更新. 我已经尝试了这样的模型指向元素.这不行. <strong ng-model='Store.Phones[$index].Name'> {{Phone.Name}}</strong>
也 <strong ng-model='PhoneName' ng-change='PhoneNameChanged()'> {{Phone.Name}}</strong>
但在这种情况下,该方法没有被解雇.
编辑
这是一个基于Angular文档中仅使用ng-repeat的示例的示例.由于ng-repeat为每次迭代创建一个新的范围,所以不应该是一个问题. <!doctype html>
<html ng-app="form-example2">
<head>
<script src="http://code.angularjs.org/1.0.5/angular.min.js"></script>
<script>
angular.module('form-example2',[]).directive('contenteditable',function() {
return {
require: 'ngModel',link: function(scope,elm,attrs,ctrl) {
// view -> model
elm.bind('blur',function() {
scope.$apply(function() {
ctrl.$setViewValue(elm.html());
});
});
// model -> view
ctrl.$render = function() {
elm.html(ctrl.$viewValue);
};
// load init value from DOM
ctrl.$setViewValue(elm.html());
}
};
});
</script>
</head>
<body>
<div ng-repeat="i in [1,2,3]">
<div contentEditable="true" ng-model="content" title="Click to edit">Some</div>
<pre>model = {{content}}</pre>
</div>
<style type="text/css">
div[contentEditable] {
cursor: pointer;
background-color: #D0D0D0;
}
</style>
</body>
</html>
原版的 这里有一个例子:http://docs.angularjs.org/guide/forms 它在“实现自定义表单控件(使用ngModel)”标题下. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
