javascript - vue.js v-for里套slot,如何访问v-for当前值?
伊谢尔伦
伊谢尔伦 2017-04-11 11:19:46
[JavaScript讨论组]

我写个组件,想实现这样的效果:

<info-list @on_data="fetch_data">
   <info-item title_field="xxx" link="/xxx/{{ item.id }}"/>
</info-list>

然后List的模板大概这样:

<script type="x/template" id="info-list">
  ...
  <p v-for="item in items">
    <slot></slot>
  </p>
  ...
</script>

Item的模板大概这样:

<script type="x/template" id="info-item">
  .....
  <a href="{{ link }}">{{ item[title_field] }}</a>
 ......
</script>

主要是问题是,slot里的组件,如何访问外层的状态。我看到stackoverflow也有人问类似的问题:
http://stackoverflow.com/questions/37248411/how-to-access-item-in-slot-inside-v-for-vue-js
还有:
http://forum.vuejs.org/topic/366/slot-as-an-item-row-template/6

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(2)
天蓬老师

只能這樣:

<info-list @on_data="fetch_data">
   <info-item v-for="item in items"/>
</info-list>

slot 是在父組件被編譯的,所以其作用域(scope)是在父組件,沒辦法在子組件傳值給 slot,可能要考慮改變下結構。

大家讲道理

正常的父子通信就行 props

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号