javascript - 网易云音乐是如何实现a标签href有值不跳转的?
问题描述
比如这个页面http://music.163.com/#/song?i...点击下面的歌名,页面没有刷新也没跳转,是如何实现的。
问题解答
回答1:http://music.163.com/#/song?i...#号后面的东西叫片段,也可以叫锚点。 这东西不会刷新浏览器,也不会提交一个请求给服务器,但是可以生成一条浏览器记录。获取#号后面的值是window.location.hash所以只需要监控这个hash值的变化就可以了onhashchange
回答2:window.location.hash
回答3:iframe
回答4:估计你是新手吧... 多看源代码吖
_onAnchorClick = function(_event){//截获所有<a>标签的点击事件,自定义页面的跳转 _event = _event||window.event; var _el = _event.target||_event.srcElement, _base = location.protocol+’//’+location.host;while(_el&&_el!=document){// ... }}_addEvent(document,’click’,_onAnchorClick);
其实就是用了 Event.preventDefault
<a href='https://baidu.com'>我想跳转到百度搜索哆啦A梦</a> <script src='https://code.jquery.com/jquery-3.1.0.js'></script> <script>$(’a’).on(’click’, function (event) { event.preventDefault(); }) </script>回答5:
页面其实就是没有刷新,你知道'#target',可以将你的页面跳转到target的位置,这个其实和这个差不多,进一步你可以了解js的hash(楼上说的),还有路由
相关文章:
1. 一个走错路的23岁傻小子的提问2. c++ - win764位环境下,我用GCC为什么指针占8个字节,而long是4个字节?3. html5 - HTML代码中的文字乱码是怎么回事?4. angular.js - angularjs 使用鼠标悬停时,标签一直闪5. java - 安卓电视盒子取得了root权限但是不能安装第三方应用,请问该怎么办?6. javascript - SuperSlide.js火狐不兼容怎么回事呢7. python 计算两个时间相差的分钟数,超过一天时计算不对8. node.js - 函数getByName()中如何使得co执行完后才return9. python - django 里自定义的 login 方法,如何使用 login_required()10. android - 安卓activity无法填充屏幕
