当点击链接时,维护标签值的干净方法是什么
What is a clean way of maintaining the hashtag value when links are clicked?
我的网站上没有外部链接,所以我想选择所有的锚标签:$('a')
,并将当前的标签值附加到所有这些标签的href中,但这似乎是一个混乱的过程。有更好的方法吗?我的网站的url看起来是这样的:www.rsadler.com/html/home.html#chairsAndTables
但当你点击我的任何链接时,url显然会更新,没有标签。谢谢
OP实际上意味着页面会发生变化,但哈希需要结转到后续的每个页面。
$('a').each(function(){
var href=this.href.split('#')[0];
$(this).attr('href', href + window.location.hash);
});
方法1:jQuery
$(document).ready(function() {
$("a").each(function(){ this.src += window.location.hash; });
});
方法2:会话Cookie
window.onload = function() {
var winHash = window.location.hash;
var cookieHash = unescape((document.cookie.match(new RegExp(''bhash=(.*?)(?:;|$)','i')) || [null,''])[1]);
if(winHash == "" && cookieHash.length > 0)
window.location.hash = cookieHash;
else if(winHash != "")
document.cookie = "hash=" + escape(winHash) + "; path=/";
}
注意我没有测试上面的JavaScript,所以可能存在语法错误。
在链接的点击事件处理程序中对事件调用preventDefault将阻止浏览器更新当前URL。
相关文章:
- 打破承诺链的好方法是什么
- 在JavaScript中拆分日期字符串的更好方法是什么
- 将jQuery.ech()方法转换为本地JavaScript抽象的最佳方法是什么
- 处理浮点错误的最佳方法是什么
- 基于窗口宽度jquery的函数的替代方法是什么
- 实现比较方法的最佳实践是什么;s的比较类型是在运行时选择的
- knex:根据结果创建数组的合适方法是什么
- 以编程方式填充组合框道场 (1.8) 的最佳方法是什么?
- node.js是否具有'match()'方法如果是,语法是什么
- 使用Modernizr检测移动设备最可靠的方法是什么
- 确定var是否是javascript中的elementFinder对象的方法是什么
- 用javascript修复这个JSON对象字符串最干净的方法是什么
- 让会话值可用于JavaScript的好方法是什么
- 从AngularJs获取谷歌地图对象的正确方法是什么
- 使用ReactJS和Flux架构从服务器获取数据的正确方法是什么
- 列出没有 mysql 的元素的最佳方法是什么
- 克服错误的更优雅的方法是什么:需要对象说明符.当通过JXA通过Messages发送SMS时,参数没有对象说明符
- 使用较少代码隐藏和显示选择菜单内容的更好方法是什么?javascript
- 在 Javascript 中实现解耦代码/回调的正确方法是什么?
- 使用Javascript,获取元素的方法是什么,基于打开和关闭标记之间的文本