比如,一下代码,是用 Modal 弹出, 点击 Sumit 没有效果。
<script> new Vue({ el: '#pop-form', methods: { submit() { alert('hi') } }, }) <script> <div id='pop-form'> <button @click="submit">Submit</button> </div>
解决方法: Dom append后再请求js,再渲染Dom就可以了
BTW, 谁知道axios 怎么实现 $.getScript
function onclick_get_form (id) { liteWaiting.show() axios.get('/path/to/html').then(function (res) { // handle success $('#modal').remove(); $('body').append(res.data); $.getScript("/path/to/script", function() { $('#modal').modal(); }); }).catch(function (error) { // handle error msg.error('error') }).then(function () { // always executed liteWaiting.hide() }) }
![]() | 1 lianyue 2018-09-15 13:16:41 +08:00 via iPhone js 放 html 尾部 |
![]() | 2 coolzjy 2018-09-15 13:38:17 +08:00 又是一个不学基础就上框架的…… |
![]() | 3 ioioioioioioi OP @coolzjy 你厉害,你牛逼 |
![]() | 4 mkeith 2018-09-15 14:08:59 +08:00 via iPhone 先去看教程,vue 不是你这样用的 |
5 SilentDepth 2018-09-15 14:22:27 +08:00 确实是一个基础问题。 浏览器解析 HTML 文档是顺序方式,遇到 script 直接解析执行,执行完毕后再继续解析下面的 HTML 内容。你的代码里,先 script,于是 Vue 就开始初始化了,然而这个时候它尝试找一个 #pop-form 元素却找不到(因为这个元素此时还没有被浏览器解析),所以就不正常了。正是因为这个,所以才有了一个常见实践就是脚本都放到 body 底部,保证需要用到的 HTML 元素已经被解析。 如果必须要保证这个 HTML 元素顺序,监听 window 的 load 事件然后在回调里初始化 Vue 实例。这也是 jQuery 的常见实践。 |
![]() | 6 ioioioioioioi OP 2018-09-15 14:31:17 +08:00 @SilentDepth 放到下面也不行。 是这样的,要做个全局函数,onclick 的时候执行:请求服务器获取 form,form 里有独立的 html 和 Vue.js 。jQuery 可以用$.getScript,但是 Vue 好像不行。 |
![]() | 7 ioioioioioioi OP @SilentDepth 好吧,$.getScript 可以的。 |
8 orange1818 2018-09-15 14:43:55 +08:00 前端开发群补点人,群号:157156558 |
![]() | 9 FEDT 2018-09-15 14:51:55 +08:00 via iPhone ![]() 二楼说的没毛病,你也回的没毛病,他确实比你厉害比你牛逼 |
![]() | 10 Kilerd 2018-09-15 14:58:18 +08:00 ![]() 同意楼上说的,2 楼说得没错。没有 MVVM 基础就先了解一下 MVVM 框架是怎么处理这些情况的。 当然,你说的也没错,谁又规定在 MVVM 里面只能用他那套规则呢? 对吧。 不过,他确实比你厉害。 |
![]() | 11 ioioioioioioi OP |
12 introom 2018-09-15 16:09:57 +08:00 via Android @ioioioioioioi 你让我开心地笑了 |
13 heww 2018-09-15 16:57:07 +08:00 via iPhone 新手者不是新手找人帮助时态度要诚恳一点儿! 二楼说的没错,这个问题的确是基础知识,和 vue 半毛钱关系都没有。 |