Ritter
V2EX  ›  Vue.js

大佬们 vue 这段动态渲染的代码为什么不行

  •  
  •   Ritter · Apr 9, 2020 · 4148 views
    This topic created in 2256 days ago, the information mentioned may be changed or developed.

    用了 elementui 组件 想动态渲染一部分 html 片段 但是为什么没有数据 G4xas1.png G4xdqx.png 新手求教 谢谢

    34 replies    2020-04-13 17:06:33 +08:00
    Ritter
        1
    Ritter  
    OP
       Apr 9, 2020
    挠头
    Ritter
        2
    Ritter  
    OP
       Apr 9, 2020
    挠头*2
    shakaraka
        3
    shakaraka  
    PRO
       Apr 9, 2020   ❤️ 1
    看着你的代码我也只能挠头*3
    also24
        4
    also24  
       Apr 9, 2020
    Vue.extend( options ) 那一句,data() 上的 warning 是怎么回事儿?
    Ritter
        5
    Ritter  
    OP
       Apr 9, 2020
    Ritter
        6
    Ritter  
    OP
       Apr 9, 2020
    @also24 哪个 warning 有红线的只是 eslint 的问题
    qq316107934
        7
    qq316107934  
       Apr 9, 2020   ❤️ 1
    这...都用了 vue 了为啥还要直接操作 DOM
    also24
        8
    also24  
       Apr 9, 2020
    @Ritter #6
    你和我说的是同一行嘛?我说的是 data() 上的 warning 那里。
    虽然我不会写前端,但是看文档的话,难道不是 data: function () 这样写么?

    https://cn.vuejs.org/v2/api/index.html#Vue-extend
    jjianwen68
        9
    jjianwen68  
       Apr 9, 2020
    转换思想,用 vue 了就不要按 jquery 那套了吧
    murmur
        10
    murmur  
       Apr 9, 2020
    template 部分有语法错误么,我这看似乎是 column 都没渲染出来啊,表头呢
    murmur
        11
    murmur  
       Apr 9, 2020
    @also24 es6 语法了解下,data()就是 function
    Ritter
        12
    Ritter  
    OP
       Apr 9, 2020
    @also24 data()上面没有 warning 这个是 es6 的语法
    Ritter
        13
    Ritter  
    OP
       Apr 9, 2020
    @qq316107934
    @jjianwen68
    因为在 echarts tooltip 格式化函数只能返回 html 片段 我又想在里面用 elementui 组件
    rain0002009
        14
    rain0002009  
       Apr 9, 2020
    您瞧瞧 您这代码和官网例子的区别
    Ritter
        15
    Ritter  
    OP
       Apr 9, 2020
    @murmur 应该没有 看类名 el-table 组件已经被编译了 但是数据没有填进去
    Ritter
        16
    Ritter  
    OP
       Apr 9, 2020
    @rain0002009 图裂了 老哥
    rabbbit
        17
    rabbbit  
       Apr 9, 2020
    tipComponent.$nextTick(() => {
    ...const html = tipComponent.$el.outerHTML
    ...console.log(html)
    })
    also24
        18
    also24  
       Apr 9, 2020
    @murmur #11
    @Ritter #12
    soga,js 果然博大精深

    14 楼贴的图是
    https://cn.vuejs.org/v2/api/index.html#vm-mount
    rabbbit
        19
    rabbbit  
       Apr 9, 2020
    直接取当然没变化, Vue 不会立刻修改 Dom.
    shintendo
        20
    shintendo  
       Apr 9, 2020
    17L 正解。
    话说你这用法也实在诡异
    Ritter
        21
    Ritter  
    OP
       Apr 9, 2020
    @rabbbit 大佬牛逼 再问一下 为什么我直接循环数据又可以显示出来 像这种传递给另一个组件的 props 的却不行
    rabbbit
        22
    rabbbit  
       Apr 9, 2020   ❤️ 1
    @Ritter 看不懂,写个完整点的例子发过来看看.
    rain0002009
        23
    rain0002009  
       Apr 9, 2020
    好了 破案了
    Ritter
        24
    Ritter  
    OP
       Apr 9, 2020
    例如我把这个 html 改成
    ````
    const tipTableHtml = '<div>
    <span v-for="d in tableData">{{ d.name }}</span>
    </div>'
    ```
    这样是直接可以看到渲染后的数据的
    还有就是我这个 formatter 函数需要返回一个 html 字符串 但是返回的字符串在$nextTick 的回调中 这要怎么办
    Ritter
        25
    Ritter  
    OP
       Apr 9, 2020
    @rabbbit 忘了 @
    rabbbit
        26
    rabbbit  
       Apr 9, 2020   ❤️ 1
    @Ritter
    element-table 里面有默认值,他会先用默认值去渲染 Dom.
    你可以试下下面这个例子, console 输出的还是默认值:

    const tipComponent = new tipComponentConstruct().$mount();
    tipComponent.tableData[0].data = 'xxx' // 注意这里
    tipComponent.$nextTick(() => {
    ...const html = tipComponent.$el.outerHTML
    ...console.log(html)
    })

    至于取 nextTick 里的值, 可以用 watch

    Vue.extend({
    ...data() {
    ......return {
    .........html: null
    ......}
    ...}
    ...watch: {
    ......html(value) {console.log(value)}
    ...}
    })
    a.$nextTick(() => {
    ...tipComponent.html = a.$el.outerHTML
    })
    rabbbit
        27
    rabbbit  
       Apr 9, 2020   ❤️ 1
    const tipComponent = new tipComponentConstruct().$mount();
    tipComponent.tableData[0].data = 'xxx'
    console.log(tipComponent.$el.outerHTML) // 漏了一行
    tipComponent.$nextTick(() => {
    ...const html = tipComponent.$el.outerHTML
    ...console.log(html)
    })
    Ritter
        28
    Ritter  
    OP
       Apr 9, 2020
    @rabbbit 明白了 谢谢大佬
    okampfer
        29
    okampfer  
       Apr 9, 2020
    element-ui 的组件同样需要 vue-loader 在打包阶段处理,echarts tooltip 格式化函数返回的 html 片段运行时才会被渲染,所以无法被处理,如果里面用了 element-ui 的组件,应该会被原样输出。

    如果我的想法有错,还请各位前端大佬指正。
    zhouyg
        30
    zhouyg  
       Apr 10, 2020
    直接赋值 el-table 是不会被编译的,只会当作成自定义 html 标签
    shenzhimin
        31
    shenzhimin  
       Apr 10, 2020
    @rabbbit 应该不需要 nexttick 的,element-table 里面有默认值是在没有传参数的时候 才会用到,应该不存在先用默认值渲染的说法
    可以看看 @rain0002009 上面的截图
    tikazyq
        32
    tikazyq  
       Apr 10, 2020
    你应该避免这么做
    ourFEer
        33
    ourFEer  
       Apr 10, 2020
    大佬,挠头 * n
    Joseph0717
        34
    Joseph0717  
       Apr 13, 2020
    铁铁,别这样,非要这样可以这样,dom=`<html></html>`,注意不双是引号
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2793 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 89ms · UTC 06:13 · PVG 14:13 · LAX 23:13 · JFK 02:13
    ♥ Do have faith in what you're doing.