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 相关文章推荐
在textarea文本域中显示HTML代码的方法
Mar 06 Javascript
$.get获取一个文件的内容示例代码
Sep 11 Javascript
让jQuery与其他JavaScript库并存避免冲突的方法
Dec 23 Javascript
js获取url中的参数且参数为中文时通过js解码
Mar 19 Javascript
详解JavaScript时间格式化
Dec 23 Javascript
用jquery快速解决IE输入框不能输入的问题
Oct 04 Javascript
微信小程序 生命周期详解
Oct 12 Javascript
第一次接触神奇的Bootstrap
Oct 14 Javascript
Vue服务端渲染和Vue浏览器端渲染的性能对比(实例PK )
Mar 31 Javascript
ionic3 懒加载
Aug 16 Javascript
vue 组件高级用法实例详解
Apr 11 Javascript
浅析前端路由简介以及vue-router实现原理
Jun 01 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+javascript液晶时钟
2006/10/09 PHP
PHP empty函数报错解决办法
2014/03/06 PHP
smarty模板引擎之分配数据类型
2015/03/30 PHP
php实现TCP端口检测的方法
2015/04/01 PHP
详解php框架Yaf路由重写
2017/06/20 PHP
ThinkPHP 在阿里云上的nginx.config配置实例详解
2017/10/11 PHP
PHP封装的验证码工具类定义与用法示例
2018/08/22 PHP
php实现构建排除当前元素的乘积数组方法
2018/10/06 PHP
JS实现切换标签页效果实例代码
2013/11/01 Javascript
jQuery数据检索中根据关键字快速定位GridView指定行的实现方法
2016/06/08 Javascript
jQuery中ajax错误调试分析
2016/12/01 Javascript
javascript防篡改对象实例详解
2017/04/10 Javascript
vue实现长图垂直居上 vue实现短图垂直居中
2017/10/18 Javascript
推荐10款扩展Web表单的JS插件
2017/12/25 Javascript
JS 音频可视化插件Wavesurfer.js的使用教程
2018/10/31 Javascript
用VueJS写一个Chrome浏览器插件的实现方法
2019/02/27 Javascript
8 个有用的JS技巧(推荐)
2019/07/03 Javascript
[42:25]EG vs Spirit Supermajor 败者组 BO3 第二场 6.4
2018/06/05 DOTA
[54:24]Optic vs TNC 2018国际邀请赛小组赛BO2 第二场
2018/08/18 DOTA
python实现apahce网站日志分析示例
2014/04/02 Python
Python的函数的一些高阶特性
2015/04/27 Python
Python Web框架Tornado运行和部署
2020/10/19 Python
Python2和3字符编码的区别知识点整理
2019/08/08 Python
python实现取余操作的简单实例
2020/08/16 Python
如何用Python 实现全连接神经网络(Multi-layer Perceptron)
2020/10/15 Python
Python GUI之tkinter窗口视窗教程大集合(推荐)
2020/10/20 Python
印度尼西亚电子产品购物网站:Kliknklik
2018/06/05 全球购物
附答案的Java面试题
2012/11/19 面试题
学习保证书范文
2014/04/30 职场文书
乡镇创先争优活动总结
2014/08/28 职场文书
建议书范文
2015/02/05 职场文书
业务员岗位职责范本
2015/04/03 职场文书
2015年小学远程教育工作总结
2015/07/28 职场文书
导游词之沈阳植物园
2019/11/30 职场文书
您对思维方式了解多少?
2019/12/09 职场文书
CentOS下安装Jenkins的完整步骤
2022/04/07 Servers