JavaScript将相对地址转换为绝对地址示例代码


Posted in Javascript onJuly 19, 2013

在看LABjs源代码时,发现里面有个将相对地址转为绝对地址的函数,将其拿出纪录如下:

function canonical_uri(src, base_path) 
{ 
var root_page = /^[^?#]*\//.exec(location.href)[0], 
root_domain = /^\w+\:\/\/\/?[^\/]+/.exec(root_page)[0], 
absolute_regex = /^\w+\:\/\//; // is `src` is protocol-relative (begins with // or ///), prepend protocol 
if (/^\/\/\/?/.test(src)) 
{ 
src = location.protocol + src; 
} 
// is `src` page-relative? (not an absolute URL, and not a domain-relative path, beginning with /) 
else if (!absolute_regex.test(src) && src.charAt(0) != "/") 
{ 
// prepend `base_path`, if any 
src = (base_path || "") + src; 
} 
// make sure to return `src` as absolute 
return absolute_regex.test(src) ? src : ((src.charAt(0) == "/" ? root_domain : root_page) + src); 
}

如当前页面地址为:http://www.inspurstb.com/hzt/index.html
则canonical_uri("scy.js")返回http://www.inspurstb.com/hzt/scy.js

用Javascript将相对路径地址,转换为绝对路径

1)使用Image, 经测试会发送一个Aborted的请求,并且IE6不支持, 将new Image改成document.createElement_x_x_x('IMG')也是一样的;测试应该不喜欢这个方案;

function getAbsoluteUrl(url){ 
var img = new Image(); 
img.src = url; // 设置相对路径给Image, 此时会发送出请求 
url = img.src; // 此时相对路径已经变成绝对路径 
img.src = null; // 取消请求 
return url; 
} 
getAbsoluteUrl("showroom/list");

2)使用Anchor(链接),不会发出任何请求,只会在加入DOM时产生请求,但是IE6也不支持
function getAbsoluteUrl(url){ 
var a = document.createElement_x_x_x('A'); 
a.href = url; // 设置相对路径给Image, 此时会发送出请求 
url = a.href; // 此时相对路径已经变成绝对路径 
return url; 
} 
getAbsoluteUrl("showroom/list");

3)使用JavaScript: 实现起来比较复杂,这里有一个例子: https://gist.github.com/1088850

最终使用的是option 2,

由此可变,用原生态的方法访问所有的Image, Anchor时,返回的都是绝对路径,此时如果想返回原来的相对路径,可以用查询DOM的方法,如jQuery的.attr()方法:

console.log($anchor[0]["href"]); //返回绝对路径,jQuery对象实质上都是数组,即使只有一个,因此使用[0]可以访问到原生态的对象,然后取"href";
console.log($anchor.attr("href")); //返回原始路径

Javascript 相关文章推荐
腾讯UED 漂亮的提示信息效果代码
Sep 12 Javascript
jquery 跳到顶部和底部动画2句代码简单实现
Jul 18 Javascript
js中数组Array的一些常用方法总结
Aug 12 Javascript
jquery append()方法与html()方法的区别及使用介绍
Aug 01 Javascript
javascript模拟map输出与去除重复项的方法
Feb 09 Javascript
win7下安装配置node.js+express开发环境
Dec 06 Javascript
浅析Bootstrap组件之面板组件
May 04 Javascript
JavaScript hasOwnProperty() 函数实例详解
Aug 04 Javascript
Ionic3实现图片瀑布流布局
Aug 09 Javascript
Node.js搭建小程序后台服务
Jan 03 Javascript
JavaScript实现与使用发布/订阅模式详解
Jan 19 Javascript
vue监听用户输入和点击功能
Sep 27 Javascript
鼠标焦点离开文本框时验证的js代码
Jul 19 #Javascript
jquery的flexigrid无法显示数据提示获取到数据
Jul 19 #Javascript
GridView中获取被点击行中的DropDownList和TextBox中的值
Jul 18 #Javascript
javascript判断非数字的简单例子
Jul 18 #Javascript
jquery 跳到顶部和底部动画2句代码简单实现
Jul 18 #Javascript
公共js在页面底部加载的注意事项介绍
Jul 18 #Javascript
利用div+jquery自定义滚动条样式的2种方法
Jul 18 #Javascript
You might like
在PHP中读取和写入WORD文档的代码
2008/04/09 PHP
如何让CI框架支持service层
2014/10/29 PHP
php通过array_push()函数添加多个变量到数组末尾的方法
2015/03/18 PHP
php实现自定义中奖项数和概率的抽奖函数示例
2017/05/26 PHP
PHP基于关联数组20行代码搞定约瑟夫问题示例
2017/11/07 PHP
PHP实现正则表达式分组捕获操作示例
2018/02/03 PHP
jquery ajax提交表单数据的两种方式
2009/11/24 Javascript
jquery下操作HTML控件的实现代码
2010/01/12 Javascript
锋利的jQuery 要点归纳(一) jQuery选择器
2010/03/21 Javascript
jquery.boxy插件的iframe扩展代码
2010/07/02 Javascript
javascript数组去掉重复
2011/05/12 Javascript
DOM基础教程之使用DOM控制表格
2015/01/20 Javascript
JavaScript的兼容性与调试技巧
2016/11/22 Javascript
node.js的事件机制
2017/02/08 Javascript
微信小程序后台解密用户数据实例详解
2017/06/28 Javascript
详解React服务端渲染从入门到精通
2019/03/28 Javascript
一起来了解一下JavaScript的预编译(小结)
2021/03/01 Javascript
[02:40]2014DOTA2 国际邀请赛中国区预选赛 四大豪门抵达华西村
2014/05/23 DOTA
python学习 流程控制语句详解
2016/06/01 Python
Python正则表达式如何进行字符串替换实例
2016/12/28 Python
Python中turtle作图示例
2017/11/15 Python
python 3.6.5 安装配置方法图文教程
2018/09/18 Python
Python os库常用操作代码汇总
2020/11/03 Python
德国电子商城:ComputerUniverse
2017/04/21 全球购物
出门问问全球官方商城:Tichome音箱和TicWatch智能手表
2017/12/02 全球购物
英国最大的专业户外零售商:Mountain Warehouse
2018/06/06 全球购物
美津浓巴西官方网站:Mizuno巴西
2019/07/24 全球购物
波兰办公用品和学校用品在线商店:Dlabiura24.pl
2020/11/18 全球购物
中兴通讯全球官方网站:ZTE
2020/12/26 全球购物
暑期社会实践学生的自我评价
2014/01/09 职场文书
学习方法演讲稿
2014/05/10 职场文书
2014年企业员工工作总结
2014/12/09 职场文书
2016年离婚协议书范文
2016/03/18 职场文书
80行代码写一个Webpack插件并发布到npm
2021/05/24 Javascript
Python实现GIF动图以及视频卡通化详解
2021/12/06 Python
mysql数据库隔离级别详解
2022/06/16 MySQL