91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在Vue中使用插槽

發布時間:2020-07-10 19:04:53 來源:網絡 閱讀:365 作者:梁十八 欄目:web開發

以下方法傳值存在兩個問題:
1.不能去掉外面包裹的標簽
2.如果要傳值的太多,這種方法很搓很難閱讀

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script src="./vue.js"></script>
    <!-- <script src="http://cdn.staticfile.org/vue/2.6.10/vue.common.dev.js"></script> -->
</head>
<body>
<div id="root">
    <child content="<p>My name is Tom Cat</p>"></child>
</div>
<script type="text/javascript">
    Vue.component("child", {
        props: ["content"],
        template: `<div>
                        <p>hello</p>
                        <br/>//把html標簽轉義顯示出來了:<br/><br/>
                        {{content}}<br/>
                        <br/>//正常渲染了html標簽(也顯示了外面包裹的div):
                        <div v-html='this.content'></div>
                        //而模版占位符template也不能去掉外面包裹的標簽,而且整個都不渲染了:<br/>
                        <template v-html='this.content'></template>
                        <br/>
                    </div>`
    });
    var vm = new Vue({
        el: "#root"
    })
</script>
</body>
</html>

那用啥方法?用插槽啊!
插槽的使用細節:

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script src="./vue.js"></script>
    <!-- <script src="http://cdn.staticfile.org/vue/2.6.10/vue.common.dev.js"></script> -->
</head>
<body>
<div id="root">
    <child>
        //這是插槽咯:
        <h2>world</h2>
    </child>

    //注意:content是保留關鍵字,不能用作組件,so 用my-content(用myContent這樣的駝峰命名會報錯):
    <my-content1>
        <div class="header">header</div>
        <div class="footer">footer</div>
    </my-content1>

    <br>//具名插槽:
    <my-content2>
        <div class="header" slot="header">header</div>
        <div class="footer" slot="footer">footer</div>
    </my-content2>
</div>
<script type="text/javascript">
    Vue.component("child", {
        //props: ["content"],
        template: `<div>
                        <p>hello</p>
                        <slot>默認內容,當父組件不傳遞插槽內容的時候顯示</slot>
                    </div>`
    });

    Vue.component("my-content1", {
        //props: ["content"],
        template: `<div>
                        <slot></slot>
                        <div class='content'>hello</div>
                        <slot></slot>
                    </div>`
    });

    Vue.component("my-content2", {
        //props: ["content"],
        template: `<div>
                        <slot name="header">不給該插槽傳值,則顯示我</slot>
                        <div class='content'>hello</div>
                        <slot name="footer"></slot>
                    </div>`
    });

    var vm = new Vue({
        el: "#root"
    })
</script>
</body>
</html>
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巴马| 徐水县| 蓝山县| 阿拉善左旗| 万盛区| 湾仔区| 志丹县| 上杭县| 资中县| 广宁县| 新河县| 汨罗市| 甘德县| 朝阳市| 武冈市| 涪陵区| 衡阳县| 泉州市| 九江县| 富锦市| 绥滨县| 区。| 内江市| 镇雄县| 龙南县| 胶州市| 双城市| 兴文县| 九台市| 丁青县| 高邑县| 习水县| 七台河市| 通海县| 江源县| 荔浦县| 西青区| 宜丰县| 钟山县| 永德县| 塔城市|