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 相关文章推荐
用原生JavaScript实现jQuery的$.getJSON的解决方法
May 03 Javascript
JavaScript中消除闭包的一般方法介绍
Mar 16 Javascript
javascript排序函数实现数字排序
Jun 26 Javascript
JavaScript DOM 学习总结(五)
Nov 24 Javascript
javascript数据结构之二叉搜索树实现方法
Nov 25 Javascript
jQuery模仿单选按钮选中效果
Jun 24 Javascript
详解vue 配合vue-resource调用接口获取数据
Jun 22 Javascript
vue axios同步请求解决方案
Sep 29 Javascript
bootstrap模态框嵌套、tabindex属性、去除阴影的示例代码
Oct 17 Javascript
JS实现对json对象排序并删除id相同项功能示例
Apr 18 Javascript
ES6 十大特性简介
Dec 09 Javascript
JS实现选项卡插件的两种写法(jQuery和class)
Dec 30 jQuery
鼠标焦点离开文本框时验证的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
造势之举?韩国总统候选人发布《星际争霸》地图
2017/04/22 星际争霸
PHP5 字符串处理函数大全
2010/03/23 PHP
php购物车实现代码
2011/10/10 PHP
php中Socket创建与监听实现方法
2015/01/05 PHP
smarty模板引擎从php中获取数据的方法
2015/01/22 PHP
php实现的美国50个州选择列表实例
2015/04/20 PHP
Zend Framework教程之Resource Autoloading用法实例
2016/03/08 PHP
简明json介绍
2008/09/28 Javascript
jquery png 透明解决方案(推荐)
2010/08/21 Javascript
用Jquery实现滚动新闻
2014/02/12 Javascript
JavaScript模拟重力状态下抛物运动的方法
2015/03/03 Javascript
JQuery中层次选择器用法实例详解
2015/05/18 Javascript
javascript封装简单实现方法
2015/08/11 Javascript
javacript获取当前屏幕大小
2016/06/04 Javascript
BootStrap Table 设置height表头与内容无法对齐的问题
2016/12/28 Javascript
利用Console来Debug的10个高级技巧汇总
2018/03/26 Javascript
Vue开发中常见的套路和技巧总结
2020/11/24 Vue.js
python在Windows8下获取本机ip地址的方法
2015/03/14 Python
Python编程实现微信企业号文本消息推送功能示例
2017/08/21 Python
Python 使用with上下文实现计时功能
2018/03/09 Python
Python用5行代码写一个自定义简单二维码
2018/10/21 Python
Python selenium根据class定位页面元素的方法
2019/02/26 Python
python opencv 简单阈值算法的实现
2019/08/04 Python
详解numpy矩阵的创建与数据类型
2019/10/18 Python
python属于解释语言吗
2020/06/11 Python
Python轻量级web框架bottle使用方法解析
2020/06/13 Python
关于Python字符编码与二进制不得不说的一些事
2020/10/04 Python
python 实现socket服务端并发的四种方式
2020/12/14 Python
HTML5之SVG 2D入门13—svg对决canvas及长处和适用场景分析
2013/01/30 HTML / CSS
使用layui框架实现点击左侧导航切换右侧内容且右侧选项卡跟随变化的效果
2020/11/10 HTML / CSS
Brydge英国:适用于Apple iPad和Microsoft Surface Pro的蓝牙键盘
2019/05/16 全球购物
Fanatics官网:运动服装、球衣、运动装备
2020/10/12 全球购物
毕业设计计划书
2014/01/09 职场文书
《山谷中的谜底》教学反思
2014/04/26 职场文书
企业法人任命书
2015/09/21 职场文书
《鲁滨逊漂流记》之六读后感(4篇)
2019/09/29 职场文书