我的页面上有多个链接.在许多链接中,我想仅根据数据库值禁用特定链接.我保持锚标记的ID等于firebase中数据库的ID,以便基于值禁用该特定ID的链接.
<a id="{{page.$id}}" ng-href="#/edit/{{page.$id}}/" target="_blank">Add</a>
如果我点击一个按钮然后我添加了下面的代码,它工作正常:
<button type="button" class="btn btn-primary" ng-click="complete(page.$id)">Complete</button>
$scope.complete=function(id)
{
var target=angular.element("a#"+id);
console.log(target);
target[0].hidden=true;
var elem= angular.element(id);
elem.context.activeElement.disabled=true;
}
上面的代码console.log返回我这样的元素:
[a#-KBp32nu3tfHPpKvlBqW, prevObject: x.fn.x.init[1], context: document, selector: "a#-KBp32nu3tfHPpKvlBqW"]
0: a#-KBp32nu3tfHPpKvlBqW
context: document
length: 1
prevObject: x.fn.x.init[1]
selector: "a#-KBp32nu3tfHPpKvlBqW"
__proto__: x[0]
通过这个我能够获取特定的锚标签ID并能够隐藏该元素.
但是,当我尝试在控制器上应用相同的代码以便在页面加载时禁用/隐藏元素时,此函数将返回parentDOM的元素.
我在控制器上的代码如下所示:
refUpdate=new Firebase("https://databseURL/"+newId);
refUpdate.on('value',function(snapshot){
var status= snapshot.child("completed").val();
if(status=="yes")
{
var target= angular.element('a#'+newId);
console.log(target);
}
});
[prevObject: x.fn.x.init[1], context: document, selector:"a#-KBp32nu3tfHPpKvlBqW"]
context: document
length: 0
prevObject: x.fn.x.init[1]
selector: "a#-KBp32nu3tfHPpKvlBqW"
__proto__: x[0]
所以我无法获得选择器值.
任何想法如何做到这一点?
最佳答案 我想,你将在boolean中拥有数据库值,你可以在标签中使用它:
<a id="{{page.$id}}" ng-href="#/edit/{{page.$id}}/" target="_blank" ng-hide="page.isHide">Add</a>
如果要禁用,可以使用ng-disabled