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

vue.compile字符串模板如何解析@click方法

vue.compile字符串模板如何解析@click方法

aluckdog 2018-08-10 12:18:38
let compileStr = Vue.compile(this.templateString)this.template = compileStr.rendertemplateString: function (scope) {       let fun = function () {         console.log('afe')       }      return `        <div>           <el-button type="primary" @click="${fun}">查询</el-button>           <el-button type="primary">详情</el-button>         </div>       `     }点击后fun不执行。。。如果修改为${fun()}有报错Invalid handler for event "click": got undefined有没一种方法可以是的能够编译处理,并且点击能正确执行fun? 我现在用的是把fun方法data里面
查看完整描述

1 回答

?
蛊毒传说

TA贡献1895条经验 获得超3个赞

`<el-button type="primary" @click="console.log('afe')">查询</el-button>`

最简单的办法, 直接把 fun 的函数体写进@click 里面.

@click="content" 会被编译成这样子:

{  onclick: function () {
    content
  }
}

所以你的写法会变成

{  onclick: function () {    function fun() {      console.log('afe')
    }
  }
}

借助IIFE, 这样写

`<el-button type="primary" @click="(${fun})()">查询</el-button>`// 结果{
  onclick: function () {
    (function fun() {
      console.log('afe')
    })()
  }
}


查看完整回答
反对 回复 2018-08-12
  • 1 回答
  • 0 关注
  • 782 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信