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 相关文章推荐
showModalDialog模态对话框的使用详解以及浏览器兼容
Jan 11 Javascript
Internet Explorer 11 浏览器介绍:别叫我IE
Sep 28 Javascript
浅谈js多维数组和hash数组定义和使用
Jul 27 Javascript
Vue响应式添加、修改数组和对象的值
Mar 20 Javascript
jQuery自定义多选下拉框效果
Jun 19 jQuery
Node 自动化部署的方法
Oct 17 Javascript
vue better-scroll插件使用详解
Jan 25 Javascript
vue axios 表单提交上传图片的实例
Mar 16 Javascript
微信小程序 简易计算器实现代码实例
Sep 02 Javascript
微信小程序开发之获取用户手机号码(php接口解密)
May 17 Javascript
js实现拖拽与碰撞检测
Sep 18 Javascript
通过实例解析json与jsonp原理及使用方法
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输出控制功能在简繁体转换中的应用
2006/10/09 PHP
php笔记之:php函数range() round()和list()的使用说明
2013/04/26 PHP
php调用google接口生成二维码示例
2014/04/28 PHP
PHP随手笔记整理之PHP脚本和JAVA连接mysql数据库
2015/11/25 PHP
Laravel框架Eloquent ORM删除数据操作示例
2019/12/03 PHP
js检测客户端不是firefox则提示下载
2007/04/07 Javascript
Javascript中的this绑定介绍
2011/09/22 Javascript
JavaScript合并两个数组并去除重复项的方法
2015/06/13 Javascript
JavaScript浏览器对象之一Window对象详解
2016/06/03 Javascript
JS全局变量和局部变量最新解析
2016/06/24 Javascript
jQuery滚动监听实现商城楼梯式导航效果
2017/03/06 Javascript
jQuery插件zTree实现单独选中根节点中第一个节点示例
2017/03/08 Javascript
js实现3D图片展示效果
2017/03/09 Javascript
canvas实现刮刮卡效果
2017/03/14 Javascript
JavaScript适配器模式详解
2017/10/19 Javascript
Vue 拦截器对token过期处理方法
2018/01/23 Javascript
JavaScript数据结构与算法之基本排序算法定义与效率比较【冒泡、选择、插入排序】
2019/02/21 Javascript
安装多版本Vue-CLI的实现方法
2020/03/24 Javascript
[01:03:09]完美世界DOTA2联赛PWL S2 Forest vs SZ 第二场 11.25
2020/11/26 DOTA
举例区分Python中的浅复制与深复制
2015/07/02 Python
玩转python爬虫之URLError异常处理
2016/02/17 Python
python使用Matplotlib画饼图
2018/09/25 Python
设置python3为默认python的方法
2018/10/31 Python
对Python 多线程统计所有csv文件的行数方法详解
2019/02/12 Python
Python嵌套函数,作用域与偏函数用法实例分析
2019/12/26 Python
详解HTML5 Canvas标签及基本使用
2020/01/10 HTML / CSS
土耳其时尚购物网站:Morhipo
2017/09/04 全球购物
LUISAVIAROMA中国官网:时尚奢侈品牌购物网站
2020/11/01 全球购物
创先争优宣传标语
2014/10/08 职场文书
医院领导班子查摆问题对照检查材料思想汇报
2014/10/08 职场文书
毕业设计指导教师评语
2014/12/30 职场文书
网络营销计划
2015/01/17 职场文书
会计手工模拟做账心得体会
2016/01/22 职场文书
python 提取html文本的方法
2021/05/20 Python
python中if和elif的区别介绍
2021/11/07 Python
Java数组详细介绍及相关工具类
2022/04/14 Java/Android