我正在用javascript dhtmlx编写代码。我在一个网格上有一个onclick事件。当我点击网格时,会出现一个我想在4秒后消失的窗口。我尝试了setTimeOut,但在连续点击2-3次之后,它搞乱了时间,几乎立即隐藏了窗口。代码如下:
var dhxWindow = new dhx.Window({
modal: false,
header: false,
footer: false,
resizable: false,
css: "toolbar",
movable: false,
height: 130,
expire: 4000
});
var toolbar = new dhx.Toolbar("toolbar_container", {
});
grid.events.on("CellClick", function (row, column, e) {
var data = [
{
id: "data1",
type: "imageButton",
},
{
id: "data2",
type: "imageButton",
},
{
id: "data3",
type: "imageButton",
}
];
toolbar.data.parse(data);
dhxWindow.attach(toolbar);
dhxWindow.show();
setTimeout(function () {
dhxWindow.hide();
}, 4000);
});我做错了什么?谢谢
发布于 2019-07-08 22:27:59
var myTimeout;
grid.events.on("CellClick", function (row, column, e) {
if(myTimeout) clearTimeout(myTimeout); // cancel timeout if present
var data = [
{
id: "data1",
type: "imageButton",
},
{
id: "data2",
type: "imageButton",
},
{
id: "data3",
type: "imageButton",
}
];
toolbar.data.parse(data);
dhxWindow.attach(toolbar);
dhxWindow.show();
myTimeout = setTimeout(function () {
dhxWindow.hide();
}, 4000); // Reinstantiate timeout
});https://stackoverflow.com/questions/56936971
复制相似问题