+(function($) { var ops = { wrap: '#tools', url: _deel.url+'/private/tools/' } if( !getHash() ) setHash('jspacker') $(ops.wrap+' .pagesider-menu li').each(function(e){ var menu = $(this).find('a').attr('data-menu')//列出所有的链接的data-menu if( menu === getHash() ){//getHash()获取地址栏的data,判断地址栏和那个data-menu相同,相同则对当前操作。 $(this).addClass('active').siblings().removeClass() loadData( menu ) } $(this).on('click', function(){ $(this).addClass('active').siblings().removeClass() loadData( menu ) }) }) function loadData(menu){ setHash( menu ) $.ajax({ url: ops.url+menu+'.php', type: 'POST', dataType: 'html', cash: true, data: {}, success: function(data, textStatus, xhr) { $(ops.wrap+' .pagecontent').html(data) } }); } function setHash(val){ return window.location.hash = '#!'+val;//设置地址栏的后面的参数 } function getHash(){ return window.location.hash.substr(2);//获取地址栏之后从第二个开始的参数 } })(window.jQuery);
20131230 each与浏览器hash的使用
关注我
我的微信公众号:前端开发博客,在后台回复以下关键字可以获取资源。
- 回复「小抄」,领取Vue、JavaScript 和 WebComponent 小抄 PDF
- 回复「Vue脑图」获取 Vue 相关脑图
- 回复「思维图」获取 JavaScript 相关思维图
- 回复「简历」获取简历制作建议
- 回复「简历模板」获取精选的简历模板
- 回复「加群」进入500人前端精英群
- 回复「电子书」下载我整理的大量前端资源,含面试、Vue实战项目、CSS和JavaScript电子书等。
- 回复「知识点」下载高清JavaScript知识点图谱
每日分享有用的前端开发知识,加我微信:caibaojian89 交流