草庐IT

javascript - jQueryMobile PhoneGap 应用程序上的后退按钮有时无响应

coder 2025-01-01 原文

我使用 jQuery Mobile (1.3.1) 和 PhoneGap (3.4) 创建了一个应用程序,并将其蒙皮以具有相当“扁平”的界面:

我遇到了一些麻烦,只有在 iOS 上,而且只是偶尔,只有一个特定屏幕上的“后退”按钮变得无响应。其他屏幕上后退按钮的相同 HTML 和 CSS 看起来不错,只是这个屏幕。这是在 chrome 中,在 devtools 中选择了按钮以突出显示其点击区域:

为了更好的衡量,这里还有标题:

此屏幕标题的代码对于应用程序中的几乎每个屏幕都是相同的:

<div data-role="header" data-theme="e" data-position="fixed" data-tap-toggle="false">
    <h1>Event Detail</h1>
    <a data-rel="back">Back</a>
</div>

我们发现,如果用户卡在这个屏幕上并强制关闭应用程序,该按钮似乎在后续使用中会按预期工作。

所以我目前的理论是标题以某种方式妨碍了后退按钮(有时)。然而,并非每次都这样的事实让我并不真正完全相信这个理论。

按钮的 z-index 设置为 10,header 的 z-index 保留为默认值(1,对吗?)。因此,即使是标题挡住了路,我的理解是 10 的 z-index 应该将按钮放在“顶部”并让它首先有机会接收点击/点击事件。

该应用程序使用 jQueryMobile 1.3.1 是因为它的创建时间和创建方式,目前升级不是一个合理的选择。 (1.4.x 中有大量重大更改)

我已经在 iOS 和 Android 上调试了该应用程序,没有抛出任何 JavaScript 错误。我完全不知道该怎么做。这个应用程序正在向成千上万的用户推出,很可能很多人,可能是大多数人,都会遇到这个错误。我宁愿不必解释(夹着尾部)强制关闭是解决此问题的唯一方法……但这就是我到目前为止一直在做的事情。

有没有人对如何解决这个问题有任何建议或想法?


更新 1:

我注意到在通过 USB 在 Safari 中远程调试应用程序时,我可以看到后退按钮上的类在点击时从 ui-btn-up-e 更改为 ui-btn-hover-e 短暂地转到 ui-btn-down-e 并返回 ui-btn-up-e - 然而应用程序不会返回! :(

按照要求,这里是应用于标题、H1 和后退按钮的 CSS:(只是“计算的”最终值,而不是所有中间覆盖值)

标题部分:

-webkit-background-clip: border-box;
-webkit-background-origin: padding-box;
-webkit-background-size: auto;
background-attachment: scroll;
background-clip: border-box;
background-color: rgb(179, 27, 27);
background-image: none;
background-origin: padding-box;
background-size: auto;
border-bottom-color: rgb(179, 27, 27);
border-bottom-style: solid;
border-bottom-width: 1px;
border-image-outset: 0px;
border-image-repeat: stretch;
border-image-slice: 100%;
border-image-source: none;
border-image-width: 1;
border-left-color: rgb(179, 27, 27);
border-left-style: solid;
border-left-width: 0px;
border-right-color: rgb(179, 27, 27);
border-right-style: solid;
border-right-width: 0px;
border-top-color: rgb(179, 27, 27);
border-top-style: solid;
border-top-width: 1px;
color: rgb(255, 255, 255);
display: block;
font-family: MyriadPro, Helvetica, sans-serif;
font-weight: bold;
height: 45px;
left: 0px;
padding-top: 1px;
position: fixed;
right: 0px;
text-shadow: rgb(85, 85, 85) 0px 1px 0px;
top: -1px;
width: 320px;
z-index: 1000;
zoom: 1;

H1:

color: rgb(255, 255, 255);
display: block;
font-family: MyriadPro, Helvetica, sans-serif;
font-size: 18px;
font-weight: bold;
height: 23px;
margin-bottom: 10px;
margin-left: 48px;
margin-right: 48px;
margin-top: 12px;
min-height: 19.799999237060547px;
outline-color: rgb(255, 255, 255);
outline-style: none;
outline-width: 0px;
overflow-x: hidden;
overflow-y: hidden;
padding-bottom: 0px;
padding-left: 0px;
padding-right: 0px;
padding-top: 0px;
text-align: center;
text-overflow: ellipsis;
text-shadow: rgb(85, 85, 85) 0px 1px 0px;
white-space: nowrap;
width: 224px;
zoom: 1;

后退按钮:

-webkit-background-clip: border-box;
-webkit-background-origin: padding-box;
-webkit-background-size: auto;
-webkit-box-shadow: none;
background-attachment: scroll;
background-clip: border-box;
background-color: rgb(179, 27, 27);
background-image: none;
background-origin: padding-box;
background-size: auto;
border-bottom-color: rgb(179, 27, 27);
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
border-bottom-style: solid;
border-bottom-width: 0px;
border-image-outset: 0px;
border-image-repeat: stretch;
border-image-slice: 100%;
border-image-source: none;
border-image-width: 1;
border-left-color: rgb(179, 27, 27);
border-left-style: solid;
border-left-width: 0px;
border-right-color: rgb(179, 27, 27);
border-right-style: solid;
border-right-width: 0px;
border-top-color: rgb(179, 27, 27);
border-top-left-radius: 4px;
border-top-right-radius: 4px;
border-top-style: solid;
border-top-width: 0px;
box-shadow: none;
color: rgb(255, 255, 255);
cursor: pointer;
display: block;
font-family: MyriadPro, Helvetica, sans-serif;
font-weight: bold;
height: 31px;
left: 5px;
margin-bottom: 0px;
margin-left: 0px;
margin-right: 0px;
margin-top: 0px;
padding-bottom: 0px;
padding-left: 0px;
padding-right: 0px;
padding-top: 0px;
position: absolute;
text-align: center;
text-decoration: none solid rgb(255, 255, 255);
text-shadow: rgb(0, 0, 0) 0px 1px 0px;
top: 15px;
vertical-align: middle;
width: 60px;
z-index: 10;
zoom: 1;

最佳答案

首先让我告诉您,您的问题可能与按钮/标题 CSS 无关。如果此错误偶尔出现并且仅在返回功能期间出现,则您的问题可能是由于 data-rel="back" 功能引起的。

与经典的 href 页面移动不同,data-rel="back" 使用 javascript 导航历史记录,它可能有效也可能无效,具体取决于您的应用内容。因为 jQuery Mobile 使用 AJAX 进行页面处理(从你的按钮我可以看到你正在使用这种方法)它也有自己的方式来处理导航历史记录。

现在,假设您的应用程序大量使用动态内容生成(包括内容删除),例如上一页从 DOM 中删除,在这种情况下 data-rel="back" 不会工作。如果上一页不存在,您将无法返回。还有其他几个因素也会影响此功能。

你可以做什么来解决这个问题:

  1. 给这个按钮一个类名甚至一个 id。之后将点击事件绑定(bind)到它(vclick 甚至更好,因为它与点击一样快,没有 300 毫秒的延迟,并且可以在桌面和移动浏览器上工作)并在每次单击此按钮时添加一个控制台输出。所以你会这样做:

    $(document).on('vclick', '#button-ID-goes-here', function(){ 
        console.log('Problematic button');
    });
    

    这样你就可以测试按钮是否被点击了。

  2. 接下来的事情有点复杂。您从未发布过您的页面 HTML,但查看您的页面图像我认为您使用的是正确的 jQuery Mobile 范例,基本上您使用的是 data-role="page" div 容器作为页面容器。您会惊讶于有多少 jQuery Mobile 开发人员不知道/理解他们需要/必须拥有它,如果他们想要一个合适的 jQuery Mobile 应用程序的话。

    看一下标题中包含此按钮的页面。将 pagebeforeshow 事件绑定(bind)到该页面并监控它是否会触发,如果它触发,您可以使用它来显示上一页和下一页。

    工作示例:http://jsfiddle.net/Gajotres/vds2U/72/

    $(document).on('pagebeforeshow', '.ui-page',function (e, data) {
        alert("Previous page : " + data.prevPage.attr('id') + " - Next page: " + $.mobile.activePage.attr('id'));
    }); 
    

    使用此解决方案检查下一页是否正确以及它是否存在。如果当您点击后退按钮时此页面事件未触发,则说明发生了一些不好的事情。

  3. 使用下一个代码作为解决方法。基本上使用页面事件并记住您的上一页。因为您当前正在使用后退按钮,所以此解决方案在这里可行。我们将使用 pagebeforeshow 事件来找出我们之前的页面,我们将把它存储到一些 JavaScript 对象中(它将在页面转换之间持续存在)。

    工作示例:http://jsfiddle.net/Gajotres/vds2U/73/

    $(document).on('pagebeforeshow', '#second',function (e, data) {
        pageHandler.prevPage = data.prevPage.attr('id');
    
        $(document).on('click', '#custom-back-button',function () {
            $.mobile.changePage( "#"+pageHandler.prevPage);
        });    
    }); 
    
    var pageHandler = {
        prevPage : null
    }
    

    这是data-rel="back" 页面处理的完整自定义解决方案。

关于javascript - jQueryMobile PhoneGap 应用程序上的后退按钮有时无响应,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23955697/

有关javascript - jQueryMobile PhoneGap 应用程序上的后退按钮有时无响应的更多相关文章

  1. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  2. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  3. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  4. ruby - 在 Ruby 中编写命令行实用程序 - 2

    我想用ruby​​编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序

  5. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  6. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  7. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  8. ruby-on-rails - date_field_tag,如何设置默认日期? [ rails 上的 ruby ] - 2

    我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问

  9. ruby-on-rails - 如何在我的 Rails 应用程序 View 中打印 ruby​​ 变量的内容? - 2

    我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby​​中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R

  10. ruby-on-rails - openshift 上的 rails 控制台 - 2

    我将我的Rails应用程序部署到OpenShift,它运行良好,但我无法在生产服务器上运行“Rails控制台”。它给了我这个错误。我该如何解决这个问题?我尝试更新ruby​​gems,但它也给出了权限被拒绝的错误,我也无法做到。railsc错误:Warning:You'reusingRubygems1.8.24withSpring.UpgradetoatleastRubygems2.1.0andrun`gempristine--all`forbetterstartupperformance./opt/rh/ruby193/root/usr/share/rubygems/rubygems

随机推荐