9

我使用此解决方案在 vuejs 组件中动态设置表格单元格:

http://forum.vuejs.org/topic/526/repeating-table-row-with-slot

这仅适用于 Vue.js v1.0.10,但不适用于当前版本 v1.0.26。

jsfiddle:https ://jsfiddle.net/peL8fuz3/

我正在尝试获取以下标记(项目对象应该在组件中可用)

<div id="vue">
    <basic-table>
        <table-cell>{{ item.id }}</table-cell>
        <table-cell>{{ item.title }}</table-cell>
    </basic-table>
</div>

Vue.js 组件(更多在小提琴)

Vue.component('basic-table', {
    template: '<table><tbody><tr v-for="item in collection" v-slot></tr></tbody></table>',
    data: function () {
        return {
            collection: [
                {id: 1, title: 'Vue'},
                {id: 2, title: 'Vue 2'},
                {id: 3, title: 'Vue 3'},
                {id: 4, title: 'Vue 4'},
            ]
        }
    }
});

任何人都知道如何解决这个问题?

编辑 还没有找到可行的解决方案-仍在搜索..

4

2 回答 2

3

很难找出到底出了什么问题,但是该代码自v1.0.18以来就被破坏了。我无法深入挖掘以消除确切的提交,但进行了一些可能影响$context._content渲染的优化。

解决方案

但是,您可以通过更改来解决您的问题

var raw = host.$options._content; 

var raw = host._context._directives.filter(function (value) {
    return !(value.Component === undefined);
})[0].el;

该更改与v1.0.26兼容。您可以在此处找到固定代码。

免责声明

我未能找到使用公共 API 实现相同结果的方法。所以这个解决方案也依赖于非公共 API,因此可能会在未来的版本中中断。

于 2016-08-19T23:11:57.123 回答
2

亚伦,我的回答可能对你的问题不满意,但你为什么不把它简化为下面的代码,但你必须使用指令和所有这些东西?

我仍在弄清楚为什么您的解决方案适用于以前的版本,而不是当前版本。:D

new Vue({
  el: '#vue',
  data: {
    items: [{
      id: 1,
      title: 'Vue'
    }, {
      id: 2,
      title: 'Vue 2'
    }, {
      id: 3,
      title: 'Vue 3'
    }, {
      id: 4,
      title: 'Vue 4'
    }, ]
  }
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/1.0.26/vue.min.js"></script>
<table border="1" class="table" id="vue">
  <tbody>
    <tr v-for="item in items">
      <td>{{item.id}}</td>
      <td>{{item.title}}</td>
    </tr>
  </tbody>
</table>

于 2016-08-18T10:31:46.197 回答