vue第二次ajax失效,第二次点击下拉框触发vue事件按钮失效

本文探讨了一个Vue应用中遇到的问题:当用户第二次选择下拉框时,对应的按钮失去响应。问题出现在每次下拉选择后会重新创建'canvas'元素,导致之前的事件监听失效。解决方案可能涉及Vue的生命周期管理和DOM操作优化,如使用Vue的`v-if`或`v-show`来控制canvas的创建和销毁,或者通过Vue的方法正确地绑定和更新事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

第二次点击下拉框触发vue事件按钮失效

问题出现的环境背景及自己尝试过哪些方法

本人新手,求大神指点

相关代码

// 请把代码文本粘贴到下方(请勿用图片代替代码)

--请选择--

{{value}}

{{running?'停!':'开始'}}

重置

function campaignChange() {

var campaignid = document.getElementById("campaign").value;

$.ajax({

url: 'member.php?campaignid='+campaignid,

type: 'GET',

async: true,

contentType: 'application/json; charset=UTF-8',

dataType: 'json',

success: function(response) {

if(document.getElementById("myCanvas")){

var element=document.getElementById("myCanvas");

element.parentNode.removeChild(element);

//window.location.reload();

}

var canvas = document.createElement('canvas');

canvas.id = 'myCanvas';

canvas.width = document.body.offsetWidth;

canvas.height = document.body.offsetHeight;

document.getElementById('main').appendChild(canvas);

new Vue({

el: '#tools',

data: {

selected: 30,

running: false,

btns: [

30, 10, 5, 2, 1

]

},

mounted() {

canvas.innerHTML = createHTML();

TagCanvas.Start('myCanvas', '', {

textColour: null,

initial: speed(),

dragControl: 1,

textHeight: 14

});

},

methods: {

reset: function() {

},

onClick: function(num) {

},

toggle: function() {

}

}

});

}

})

}

你期待的结果是什么?实际看到的错误信息又是什么?

第二次点击下拉菜单时button失效,无法点击,请大神指点

因为每次点击都会新建myCanvas,所以我把之前创建的删除了

if(document.getElementById("myCanvas")){

var element=document.getElementById("myCanvas");

element.parentNode.removeChild(element);

//window.location.reload();

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值