首先,需要梳理一下问题的背景和现象:
首先,需要梳理一下问题的背景和现象:
背景:当网页中使用了fastclick插件时
现象:用户在点击日期选择控件时,控件无法弹出日期选择框,无法选择日期。
这是因为fastclick插件会阻止浏览器默认的双击事件(有些日期选择控件在点击两次时才能弹出)和移动端的300ms延迟,从而提升点击体验。然而这个插件的实现方式是,将点击事件改为tap事件,从而可能会对一些控件产生影响。
解决方案:
- 禁用fastclick对页面中所有input、textarea、select、button类型元素的tap事件:
window.addEventListener('load', function() {
FastClick.attach(document.body);
FastClick.prototype.focus = function(targetElement){
targetElement.focus();
};
}, false);
上述代码通过将FastClick原型中的focus方法改写,实现了让input元素获取到焦点的功能。需要注意的是,这种做法会影响整个页面,包括所有input、textarea、select、button类型的元素,可能会对页面的交互体验产生影响。
- 只禁用fastclick对日期选择控件的tap事件:
if ('addEventListener' in document) {
document.addEventListener('DOMContentLoaded', function() {
FastClick.attach(document.body);
FastClick.prototype.focus = function(targetElement){
if (targetElement.tagName === 'INPUT' && targetElement.getAttribute('type') === 'date') {
targetElement.focus();
return false;
} else {
targetElement.focus();
}
};
}, false);
}
上面这段代码对FastClick原型中的focus方法进行了针对性的改写,对于input[type="date"]类型的元素,强制执行targetElement.focus()方法,从而让其弹出日期选择框。对于其他元素,则沿用原来的逻辑。
通过以上两种方式,可以在不影响网页整体操作体验的前提下,解决“fastclick插件导致日期(input[type="date"])控件无法被触发”的问题。
本文标题为:fastclick插件导致日期(input[type=”date”])控件无法被触发该如何解决


基础教程推荐
- JavaScript操作元素教你改变页面内容样式 2023-08-12
- vue项目上安装SCSS 2023-10-08
- “Windows Phone HTML5 App”和“Javascript Windows Store Project”之间的区别 2023-10-25
- 编写轻量ajax组件第三篇实现 2022-12-18
- JS中prototype的用法实例分析 2023-12-01
- layer.open+iframe页窗口=在父页面调用iframe子页面函数 2022-10-05
- ES6中class方法及super关键字 2022-07-24
- Chrome安装vue-devtools插件 2023-10-08
- javascript中window.open在原来的窗口中打开新的窗口(不同名) 2023-12-01
- jsp+ajax实现无刷新上传文件的方法 2022-12-18