Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了angularjs – 如何通过指令更改图像源属性大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有以下图片标签

<img src="default.png" data-new-image/>

newImage是我定义的一个指令,它将从服务器获取图像(基于某些条件),在计算和获取图像时,我显示了default.png图像文件.

在这个指令中,我将链接函数定义为:

return {
    link: function (scope,element,attrs) {
        //My custom logic here to determine which image to show
        //and then fetch from the server
        //After http request,assigning image to image source
        attrs.src = "image_fetched_from_server.png";
    }
};

但是这不会更新图像src属性.我可以看到清晰的图像和分配图像后的console.log(attrs)显示属性已更新为新图像.但是浏览器中的DOM检查器显示没有对源的更改 – 它仍然显示default.png

在这里使用指令而不是控制器 – 我知道我可以使用控制器并使用Ng-src但我在多个控制器上有这个逻辑,指令是我的最佳选择.如何更改图像标记的来源?我想知道ng-src是怎么做到的?

解决方法

@H_607_23@ 我找到了原因.

要在属性中设置值,我需要使用attrs.$set(attribute_name,value).

因此,我用attrs替换了attrs.src.$set(‘src’,’image_fetched_from_server.png’);它工作了!

大佬总结

以上是大佬教程为你收集整理的angularjs – 如何通过指令更改图像源属性全部内容,希望文章能够帮你解决angularjs – 如何通过指令更改图像源属性所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。