• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

javascript - typeahead.js iOS Safari 与独立 Web 应用程序的差异

[复制链接]
菜鸟教程小白 发表于 2022-12-13 07:18:36 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我了解 typeahead.js 尚不支持移动设备。

即使它在移动浏览器(移动 Safari)中工作,是否有人知道为什么一旦通过网页的“独立”版本查看表单后它可能无法工作?

正在发生的问题是,当我尝试“单击/触摸”建议下拉菜单时,它不会在独立版本中使用该条目填充输入,而 safari 版本确实可以工作。

这种行为是否在任何地方都有记录或在 iOS 中为人所知?

谢谢。

补充:我在 .tt-suggestion 中添加了一个 jquery 委托(delegate)点击监听器以显示警报,该警报适用于移动 safari,但不适用于独立版本(我认为委托(delegate)事件未附加)。

$(document).on('click', '.tt-suggestion', function(e) {
  alert('clicked');
});



Best Answer-推荐答案


我意识到我也在使用 FastClick 库,它会破坏下拉菜单和所选选项之间的延迟。

要解决此问题,请绑定(bind)一个 dom 突变监听器并将 needsclick 类添加到每个

:

$('.tt-dropdown-menu').bind('DOMNodeInserted', function(e) {
  $(e.target).find('.tt-suggestion').children('p').addClass('needsclick');
});

您也可以尝试使用监听器:

$('input.typeahead').change(function(e) {
  $(this).closest('.tt-dropdown-menu').find('.tt-suggestion').children('p').addClass('needsclick');
});

或者使用事件委托(delegate)器:

$('.tt-dropdown-menu').click(function(e) {
  $(e.target).children('p').addClass('needsclick');
});

注意:函数未经测试,它们基于内存。

关于javascript - typeahead.js iOS Safari 与独立 Web 应用程序的差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22651312/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap