V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
clino
V2EX  ›  JavaScript

在Javascript里如何跳转到一个已有界面元素的显示?

  •  
  •   clino · 2013-11-06 09:46:20 +08:00 · 3236 次点击
    这是一个创建于 3817 天前的主题,其中的信息可能已经有所发展或是发生改变。
    具体我的情况是点击一个缩略图要跳到底下大图的地方,开始想用anchor跳转,但是第二次点击就不跳了,因为地址栏上已经是这个anchor了
    谢谢!
    9 条回复    1970-01-01 08:00:00 +08:00
    judasnow
        1
    judasnow  
       2013-11-06 09:56:45 +08:00   ❤️ 1
    我想到了两个方法
    1 用 scrollTo
    2 还是用 anchor ,但是要在 缩略图元素上绑定一个 click 回调 ,设置一个 定时器 一秒钟(比如)之后 ,修改下 url ,删除锚点信息。
    Kaiyuan
        2
    Kaiyuan  
       2013-11-06 09:56:49 +08:00   ❤️ 1
    NemoAlex
        3
    NemoAlex  
       2013-11-06 10:00:17 +08:00   ❤️ 1
    取大图在页面上的纵向相对位置,如果页面布局比较固定的话可以用固定值,例如100
    document.body.scrollTop = 100
    tonitech
        4
    tonitech  
       2013-11-06 10:15:43 +08:00   ❤️ 1
    点击获取大图到页面顶部的距离,然后让页面滚动都这个位置。
    switch
        5
    switch  
       2013-11-06 10:22:50 +08:00   ❤️ 2
    可以获取大图 element,然后调用 element.scrollIntoView(true);
    yushiro
        6
    yushiro  
       2013-11-06 10:44:06 +08:00
    5楼正解。
    clino
        7
    clino  
    OP
       2013-11-07 12:51:55 +08:00
    @switch 最后用5楼的方式搞定,代码:

    $("#imgview")[0].scrollIntoView(true)
    tonitech
        8
    tonitech  
       2013-11-13 09:47:47 +08:00
    @clino 涨姿势了
    miniwade514
        9
    miniwade514  
       2013-11-14 16:25:35 +08:00 via Android   ❤️ 1
    @clino 你可以再看一下这个帖子http://stackoverflow.com/questions/9445842/does-scrollintoview-work-in-all-browsers
    既然你已经用jquery了...
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5260 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 34ms · UTC 08:33 · PVG 16:33 · LAX 01:33 · JFK 04:33
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.