问题代码

<!--这里的muted绑定不起作用-->
<audio :muted="isMuted" ref="audioPlayer"></audio>

援引Github上的issue回复

在这里插入图片描述

翻译:muted属性类似于<input>value属性,如果他在元素初始化时是内联的,那么属性值将作为初始值;但是如果在一开始并没有内联,只是后续更改了attribute 1 值,那么将不会起任何效果,正确的做法是设置相对应的property 1 值。

解决方式:使用watch来手动设置muted

html

<audio ref="audioPlayer"></audio>

javascript

watch:{
	isMuted(val){
		if(val){
			this.$refs.audioPlayer.muted = 'muted'
		}
		else{
			this.$refs.audioPlayer.muted = ''
		}
	}
}

以上


  1. 关于attribute和property值的区别,可以看我往期的文章↩︎ ↩︎

Logo

前往低代码交流专区

更多推荐