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 相关文章推荐
jQuery提交多个表单的小例子
Jun 30 Javascript
纯文字版返回顶端的js代码
Aug 01 Javascript
深入剖析JavaScript中的函数currying柯里化
Apr 29 Javascript
jQuery+ajax实现实用的点赞插件代码
Jul 06 Javascript
jquery移除了live()、die(),新版事件绑定on()、off()的方法
Oct 26 Javascript
详谈commonjs模块与es6模块的区别
Oct 18 Javascript
AngularJS基于http请求实现下载php生成的excel文件功能示例
Jan 23 Javascript
angular6.0开发教程之如何安装angular6.0框架
Jun 29 Javascript
vue.js轮播图组件使用方法详解
Jul 03 Javascript
javascriptvoid(0)含义以及与"#"的区别讲解
Jan 19 Javascript
在Vue环境下利用worker运行interval计时器的步骤
Aug 01 Javascript
layui在form表单页面通过Validform加入简单验证的方法
Sep 06 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原型模式
2014/11/25 PHP
PHP中的traits实现代码复用使用实例
2015/05/13 PHP
PHP编程实现脚本异步执行的方法
2017/08/09 PHP
个人总结的一些关于String、Function、Array的属性和用法
2007/01/10 Javascript
JavaScript 事件记录使用说明
2009/10/20 Javascript
ModelDialog JavaScript模态对话框类代码
2011/04/17 Javascript
js URL参数的拼接方法比较
2012/02/15 Javascript
文本框获得焦点和失去焦点的判断代码
2012/03/18 Javascript
JavaScript中使用Substring删除字符串最后一个字符
2013/11/03 Javascript
JS截取url中问号后面参数的值信息
2014/04/29 Javascript
IE6-IE9中tbody的innerHTML不能赋值的解决方法
2014/06/05 Javascript
JS中getYear()和getFullYear()区别分析
2014/07/04 Javascript
2种jQuery 实现刮刮卡效果
2015/02/01 Javascript
javascript使用闭包模拟对象的私有属性和方法
2016/10/05 Javascript
Vue.js第二天学习笔记(vue-router)
2016/12/01 Javascript
Angular整合zTree的示例代码
2018/01/24 Javascript
vue项目中使用百度地图的方法
2018/06/08 Javascript
iView框架问题整理小结
2018/10/16 Javascript
微信小程序合法域名配置方法
2019/05/06 Javascript
Vue记住滚动条和实现下拉加载的完美方法
2020/07/31 Javascript
[01:35:53]完美世界DOTA2联赛PWL S3 Magma vs GXR 第二场 12.13
2020/12/17 DOTA
[01:09:19]DOTA2-DPC中国联赛 正赛 VG vs Aster BO3 第二场 2月28日
2021/03/11 DOTA
Django日志模块logging的配置详解
2017/02/14 Python
pandas系列之DataFrame 行列数据筛选实例
2018/04/12 Python
python实现雨滴下落到地面效果
2018/06/21 Python
spark dataframe 将一列展开,把该列所有值都变成新列的方法
2019/01/29 Python
python十进制转二进制的详解
2020/02/07 Python
校长岗位职责
2013/11/26 职场文书
百度吧主申请感言
2014/01/12 职场文书
运动会开幕式邀请函
2014/01/22 职场文书
应届生求职信范文
2014/05/26 职场文书
2015年会计工作总结范文
2015/05/26 职场文书
2016教师廉洁教育心得体会
2016/01/13 职场文书
python 下载文件的几种方式分享
2021/04/07 Python
利用python Pandas实现批量拆分Excel与合并Excel
2021/05/23 Python
《巫师》是美食游戏?CDPR10月将推出《巫师》官方食谱
2022/04/03 其他游戏