日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

Vue 中 $attrs 的使用

發布時間:2023/12/31 综合教程 42 生活家
生活随笔 收集整理的這篇文章主要介紹了 Vue 中 $attrs 的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

名詞解釋:

$attrs--繼承所有的父組件屬性(除了prop傳遞的屬性、class 和 style )

inheritAttrs:默認值true,繼承所有的父組件屬性(除props的特定綁定)作為普通的HTML特性應用在子組件的根元素上,如果你不希望組件的根元素繼承特性設置inheritAttrs: false,但是class屬性會繼承

主要用途

用在父組件傳遞數據給子組件或者孫組件

<body>

<div id="app" class="demo">
<base-input label="姓名" class="username-input" placeholder="Enter your username" data-date-picker="activated"></base-input>
</div>
<script src="js/vue-2.5.13.js"></script>
<script>
Vue.component("base-input", {
inheritAttrs: false, //此處設置禁用繼承特性
props: ["label"],
template:
'<label>' //這里的label元素 因為inheritAttrs: false,所以無法從<base-input>元素中繼承placeholder,data-date-picker屬性,但是class屬性會繼承
+' {{label}}'
+' {{$attrs.placeholder}}'
+' {{$attrs["data-date-picker"]}}'
+' <input v-bind="$attrs"/>' //<base-input>元素中,除了class,label(proprs中已經有了)外,剩下placeholder 和data-date-picker的屬性以及屬性值全部繼承過來了
+' </label>'
,
mounted: function() {
console.log(this.$attrs);
}
})
const app = new Vue({
el: '#app',
data: {

}

});

</script>

</body>

渲染出來的結果:

<label class="username-input">
姓名
Enter your username
activated
<input placeholder="Enter your username" data-date-picker="activated">
</label>

如果把上面例子中的inheritAttrs: false去掉或者改為inheritAttrs: true,最終渲染為:

<label placeholder="Enter your username" data-date-picker="activated" class="username-input">
姓名
Enter your username
activated
<input placeholder="Enter your username" data-date-picker="activated">
</label>

總結

以上是生活随笔為你收集整理的Vue 中 $attrs 的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。