JAVA、PHP、前端、APP、网站开发 - 开发技术学习

开发技术学习 » 前端设计 » js parse_url函数功能

js parse_url函数功能

此文被围观3994日期: 2015-01-13 分类 : 前端设计  标签:  ···

<script>

function parseURL(url) {

    var a =  document.createElement('a');

    a.href = url;

    return {

        source: url,

        protocol: a.protocol.replace(':',''),

        host: a.hostname,

        port: a.port,

        query: a.search,

        params: (function(){

            var ret = {},

                seg = a.search.replace(/^?/,'').split('&'),

                len = seg.length, i = 0, s;

            for (;i<len;i++) {

                if (!seg[i]) { continue; }

                s = seg[i].split('=');

                ret[s[0]] = s[1];

            }

            return ret;

        })(),

        file: (a.pathname.match(//([^/?#]+)$/i) || [,''])[1],

        hash: a.hash.replace('#',''),

        path: a.pathname.replace(/^([^/])/,'/$1'),

        relative: (a.href.match(/tps?://[^/]+(.+)/) || [,''])[1],

        segments: a.pathname.replace(/^//,'').split('/')

    };

}

var myURL = parseURL('http://abc.com:8080/dir/index.html?id=255&m=hello#top');

  

myURL.file;     // = 'index.html'

myURL.hash;     // = 'top'

myURL.host;     // = 'abc.com'

myURL.query;    // = '?id=255&m=hello'

myURL.params;   // = Object = { id: 255, m: hello }

myURL.path;     // = '/dir/index.html'

myURL.segments; // = Array = ['dir', 'index.html']

myURL.port;     // = '8080'

myURL.protocol; // = 'http'

myURL.source;   // = 'http://abc.com:8080/dir/index.html?id=255&m=hello#top'

</script>


js url解析

站点声明:部分内容源自互联网,为传播信息之用,如有侵权,请联系我们删除。

© Copyright 2011-2024 www.kfju.com. All Rights Reserved.
超级字帖 版权所有。蜀ICP备12031064号