Jquery 在移动端如何让返回能够不刷新页面? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hoythan
V2EX    jQuery

Jquery 在移动端如何让返回能够不刷新页面?

  •  
  •   hoythan 2016 年 12 月 21 日 7192 次点击
    这是一个创建于 3382 天前的主题,其中的信息可能已经有所发展或是发生改变。

    https://segmentfault.com/q/1010000007863491?_ea=1476187

    在移动端,我有一个按钮,点击后会弹出一个 di 层, 用户选择好内容后可以点击确定关闭这个 div, 这个步骤因为在同一个页面是没有跳转的.

    但是因为担心的误触返回导致按钮这个界面东西都白填了就不好了

    想问下能不能实现弹出的 div 层的时候 点击返回按钮能够控制仅仅关闭 div 层不回跳?

    有人提到了 onbeforeunload,onunload,onpagehide ,但是不会用?

    15 条回复    2016-12-22 10:31:37 +08:00
    jarlyyn
        1
    jarlyyn  
       2016 年 12 月 21 日
    onlyhot
        2
    onlyhot  
       2016 年 12 月 21 日 via iPhone
    弹出表单后隐藏返回按键不就好了?
    别人都提供思路了,你说不会用也是厉害,翻手册去
    onlyhot
        3
    onlyhot  
       2016 年 12 月 21 日 via iPhone
    另外,弹出表单,你给返回按键重新定义触发函数也行啊
    hoythan
        4
    hoythan  
    OP
       2016 年 12 月 21 日
    @onlyhot 如果我能控制手机的返回按钮我还费个什么劲啊
    hoythan
        5
    hoythan  
    OP
       2016 年 12 月 21 日
    @onlyhot 绑定浏览器返回按钮的触发函数是什么?
    hoythan
        6
    hoythan  
    OP
       2016 年 12 月 21 日
    @onlyhot 如何隐藏浏览器的返回按钮?
    hoythan
        7
    hoythan  
    OP
       2016 年 12 月 21 日
    @onlyhot 控制浏览器的按钮的手册在哪里?
    BOYPT
        8
    BOYPT  
       2016 年 12 月 21 日   1
    使用 router, 用户点击功能时候跳转的是#hashtag ,这样返回按钮是在用户的记录中跳转(而不会跳转页面)。
    有些 router 也兼容楼上说的 history api 。
    ragnaroks
        9
    ragnaroks  
       2016 年 12 月 21 日   1
    页面关闭时先执行 onbeforeunload,后 onunload,重写 onbeforeunload 方法(最常见的就是你关闭当前页面,会提示你是否确定离开),不过可能有的手机浏览器并不支持.
    hoythan
        10
    hoythan  
    OP
       2016 年 12 月 21 日
    @BOYPT 非常感谢,原来锚链接可以记录跳转,这样就好办了.
    Biwood
        11
    Biwood  
       2016 年 12 月 21 日   1
    非常简单,弹出 div 层的时候给当前页面的 url 赋值一个 hash ,同时绑定 onhashchange 事件,点返回的时候,页面不会刷新,只是 hash 变化了,同时可以在 hashchange 事件绑定的函数里面关闭 div 弹窗
    BOYPT
        12
    BOYPT  
       2016 年 12 月 21 日
    @Biwood 这就是 router 实现的,我但是觉得自己实现要很繁琐; 我以前项目用过 director https://github.com/flatiron/director
    都两年没更新了,没支持 history api 。

    @hoythan
    比较新的库比如 https://github.com/tildeio/router.js/ 就支持 history api 。
    最明显的例子是 github 的源码浏览窗口, 点击源码目录, url 栏目随即变化,但是页面不刷新,把 url 复制出去重新打开,也能回到这个目录;
    learnshare
        13
    learnshare  
       2016 年 12 月 21 日
    pushState ,看起来又要推荐 Vue/React/Ng 了
    GeoffZhu
        14
    GeoffZhu  
       2016 年 12 月 21 日
    最简单的办法,不应该是弹窗上放一个明显的 X ,让用户点这个关。如果不能放,控制 history 是最好的方法
    maijiawei
        15
    maijiawei  
       2016 年 12 月 22 日
    history.go(-1)
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     4644 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 04:06 PVG 12:06 LAX 21:06 JFK 00:06
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86