标签:解决方案 ref target sea theme http parse 方案 index
做前端的,应该有不少人都写过操作URL的代码,比如提取问号后面的参数、或者主机名什么的,比如这样:
var url="http://jszai.com/foo?bar=baz", separator=url.indexOf(‘?‘) >-1?‘&‘:‘?‘; url+=separator+encodeURIComponent("foo")+"="+encodeURIComponent("bar");
这类代码写多了也觉得很烦,如果有一个比较全面的解决方案就好了。
URI.js是一个全能的操作URL的库,可以方便地提取和编辑URL中的任意一部分,而且语法优雅。
它的主要功能包括:
var url=new URI("http://jszai.com/foo?bar=baz"); url.host(); // => jszai.com url.addQuery("hello","jszai"); // => http://jszai.com/foo?bar=baz&hello=jszai url.query(true); // => { foo: "bar", hello : "jszai" }
var relative_path=new URI(‘../static/css/style.css‘); relative_path.absoluteTo(‘http://jszai.com/hello-world‘); // => http://jszai.com/static/css/style.css
var uri=new URI("/hello/foo/woo/.././../world.html"); uri.normalizePathname(); // 清理路径 // uri == "/hello/world.html"
var a="http://example.org/foo/bar.html?foo=bar&hello=world&hello=mars#fragment"; var b="http://exAMPle.org:80/foo/../foo/bar.html?foo=bar&hello=world&hello=mars#fragment"; a!==b; URI(a).equals(b)===true; // 比较的时候,参数的顺序不一样也没关系 b="http://example.org/foo/bar.html?hello=mars&foo=bar&hello=world&#fragment"; a!==b; URI(a).equals(b)===true;
var result=URI.parse("http://example.org/foo.html"); result==={ protocol:"http", username:null, password:null, hostname:"example.org", port:null, path:"/foo.html", query:null, fragment:null }; var result=URI.parseQuery("?foo=bar&hello=world&hello=mars&bam=&yup"); result==={ foo:"bar", hello:["world","mars"], bam:"", yup:null };
其他特性还有更多,总之,基本上就没有想不到的功能了,但强大也是有代价的,就是源文件比较大(源代码45KB),至于用不用,就只能自己权衡了。
标签:解决方案 ref target sea theme http parse 方案 index
原文地址:http://www.cnblogs.com/tinaluo/p/7609864.html