为了账号安全,请及时绑定邮箱和手机立即绑定

vue2 使用Slot 分发内容及props数据传递

标签:
Vue.js

我对solt的理解是当组件中某一项需要单独定义,那么就应该使用solt。 举例说明。例如项目中需要一个模态框提示 付款成功,付款失败。那么这个模态框也就仅仅差这几个字或者是状态图片而已。那么此时应用solt就是一个非常不错的选择。
最初在 <slot> 标签中的任何内容都被视为备用内容。备用内容在子组件的作用域内编译,并且只有在宿主元素为空,且没有要插入的内容时才显示备用内容。

单个slot情况

//index.html<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app">
  <ol>
    <children :todo="sites">
      <span>你是谁</span>
    </children>
    </ol></div><!-- <slot><a href="">默认效果</a></slot> --><script>new Vue({
  el: '#app',
  components:{    'children':
     {
      props: ['todo'],
      template: '<div><li>{{ todo }}</li></div>'
    }
  },
  data: {
    sites:  'Runoob' 
  }
})</script></body></html>

输出结果:


webp

我们发现写在 children模板内部的span被默认删除了。如果想让span显示那么此刻就应该使用slot。
代码实例:对index.html的代码做如下修改

//index.html<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app">
  <ol>
    <children :todo="sites">
      <span>你是谁</span>
    </children>
    </ol></div><script>new Vue({
  el: '#app',
  components:{
    'children':
     {
      props: ['todo'],
      template: '<div><li>{{ todo }}</li><slot><a href="">默认效果</a></slot></div>'
    }
  },
  data: {
    sites:  'Runoob' 
  }
})</script></body></html>

webp

那么此时span标签的内容就被渲染出来了。如果在childrem中如果不写span标签那么slot默认会渲染slot里面的内容。


webp

具名slot

上面案例中讲解的是当组件的模板中有一个slot的方法,那么一个组件中如果想使用多个slot那么此时就应该使用具名slot。<slot> 元素可以用一个特殊的属性 name 来配置如何分发内容。多个 slot 可以有不同的名字。具名 slot 将匹配内容片段中有对应 slot 特性的元素。仍然可以有一个匿名 slot ,它是默认 slot ,作为找不到匹配的内容片段的备用插槽。如果没有默认的 slot ,这些找不到匹配的内容片段将被抛弃。
代码实例:对index.html的代码做如下修改:

<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app">
  <ol>
    <todo-item :todo="sites">
      <div slot="header">
        <p>我是header</p>
      </div>
      <div>
        这个是默认的没有具名的solt      </div>
      <div slot="footer">
          <p>我是footer</p>
      </div>
    </todo-item>
  </ol></div><script>new Vue({
  el: '#app',
  components:{
    'todo-item':
     {
      props: ['todo'],
      template: '<div><slot name="header"><a href="">默认效果1</a></slot><li>{{ todo }}</li><slot name="footer"><a href="">默认效果2</a></slot></div>'
    }
  },
  data: {
    value:"",
    sites: 'Runoob',
  }
})</script></body></html>

webp

给slot添加事件并通过props将改变的数据value值传递给子组件children

代码实例:对index.html的代码做如下修改:

//index.html<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app">
  <ol>
    <todo-item :todo="sites" :getvalues="value">
      <div slot="header">
        <p @click="clickme">{{value}}</p>
      </div>
      <div>
        这个是默认的没有具名的solt      </div>
      <div slot="footer">
          <p>我是footer</p>
      </div>
    </todo-item>
  </ol></div><script>new Vue({
  el: '#app',
  components:{
    'todo-item':
     {
      props: ['todo','getvalues'],
      template: '<div><slot name="header"><a href="">默认效果1</a></slot><li>{{ todo }}----{{getvalues}}</li><slot name="footer"><a href="">默认效果2</a></slot></div>'
    }
  },
  data: {
    value:"空空如也",
    sites: 'Runoob',
  },
  methods:{
    clickme(){
      this.value="我是传过来的header";
    }
  }
})</script></body></html>

webp

点击“点我试试”后结果如下如所示:


webp



作者:world_7735
链接:https://www.jianshu.com/p/4128e297f24d


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消