{"id":8508,"date":"2021-07-01T14:15:34","date_gmt":"2021-07-01T06:15:34","guid":{"rendered":"https:\/\/sdeno.com\/?p=8508"},"modified":"2021-07-01T14:28:45","modified_gmt":"2021-07-01T06:28:45","slug":"vue%e5%a4%9a%e5%b1%82%e7%ba%a7%e7%bb%84%e4%bb%b6%e5%b5%8c%e5%a5%97%e4%bc%a0%e5%8f%82v-bindattrs-v-onlisteners","status":"publish","type":"post","link":"https:\/\/sdeno.com\/?p=8508","title":{"rendered":"vue\u591a\u5c42\u7ea7\u7ec4\u4ef6\u5d4c\u5957\u4f20\u53c2v-bind=\"$attrs\" v-on=\"$listeners\""},"content":{"rendered":"<p>Vue v2.4\u65b0\u589e$attrs\u00a0$listeners<\/p>\n<p>\u76f4\u63a5\u4e0a\u6848\u4f8b\uff1a<\/p>\n<p>html\uff1a<\/p>\n<pre>&lt;div id=\"app\"&gt;\r\n    &lt;child1\r\n            :p-child1=\"child1\"\r\n            :p-child2=\"child2\"\r\n            :p-child-attrs=\"1231\"\r\n            v-on:test1=\"onTest1\"\r\n            v-on:test2=\"onTest2\"&gt;\r\n    &lt;\/child1&gt;\r\n&lt;\/div&gt;<\/pre>\n<p>&nbsp;<\/p>\n<p>js\uff1a<\/p>\n<pre>Vue.component(\"Child1\", {\r\n    inheritAttrs: true,\r\n    props: [\"pChild1\"],\r\n    template: `\r\n    &lt;div class=\"child-1\"&gt;\r\n    &lt;p&gt;in child1:&lt;\/p&gt;\r\n    &lt;p&gt;props: {{pChild1}}&lt;\/p&gt;\r\n    &lt;p&gt;$attrs: {{this.$attrs}}&lt;\/p&gt; \/\/\u9664\u4e86class\u3001style\u548cprops\uff0c\u8fd9\u91cc\u90fd\u80fd\u83b7\u53d6\u5230\u7236\u7ec4\u4ef6\u4f20\u6765\u7684\u503c{ \"p-child2\": \"pChild2\u7684\u503c\", \"p-child-attrs\": 1231 }\r\n    &lt;hr&gt;\r\n    &lt;child2 v-bind=\"$attrs\" v-on=\"$listeners\"&gt;&lt;\/child2&gt;&lt;\/div&gt;`,\r\n    mounted: function() {\r\n        this.$emit(\"test1\");\r\n    }\r\n});\r\n\r\nVue.component(\"Child2\", {\r\n    inheritAttrs: true,\r\n    props: [\"pChild2\"],\r\n    template: `\r\n    &lt;div class=\"child-2\"&gt;\r\n    &lt;p&gt;in child-&gt;child2:&lt;\/p&gt;\r\n    &lt;p&gt;props: {{pChild2}}&lt;\/p&gt;\r\n    &lt;p&gt;$attrs: {{this.$attrs}}&lt;\/p&gt;\r\n      &lt;button @click=\"$emit('test2','\u6309\u94ae\u70b9\u51fb')\"&gt;\u89e6\u53d1\u4e8b\u4ef6&lt;\/button&gt;\r\n    &lt;hr&gt; &lt;\/div&gt;`,\r\n    mounted: function() {\r\n        this.$emit(\"test2\");\r\n    }\r\n});\r\n\r\nconst app = new Vue({\r\n    el: \"#app\",\r\n    data: {\r\n        child1: \"pChild1\u7684\u503c\",\r\n        child2: \"pChild2\u7684\u503c\"\r\n    },\r\n    methods: {\r\n        onTest1() {\r\n            console.log(\"test1 running...\");\r\n        },\r\n        onTest2(value) {\r\n            console.log(\"test2 running...\" + value);\r\n        }\r\n    }\r\n});<\/pre>\n<p><a href=\"https:\/\/www.jianshu.com\/p\/a388d38f8c69\" target=\"_blank\" rel=\"noopener\">https:\/\/www.jianshu.com\/p\/a388d38f8c69<\/a><\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Vue v2.4\u65b0\u589e$attrs\u00a0$listeners \u76f4\u63a5\u4e0a\u6848\u4f8b\uff1a html\uff1a &lt;div id=&#8221;ap [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[11],"tags":[],"class_list":["post-8508","post","type-post","status-publish","format-standard","hentry","category-11"],"_links":{"self":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/posts\/8508","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=8508"}],"version-history":[{"count":0,"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/posts\/8508\/revisions"}],"wp:attachment":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=8508"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=8508"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=8508"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}