欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

javascript将url解析为json格式的两种方法

程序员文章站 2022-11-26 11:16:19
本文介绍了javascript将url解析为json格式的两种方法,分享给大家,具体如下: 方法一:最简单的方法,利用a标签来实现 function parse...

本文介绍了javascript将url解析为json格式的两种方法,分享给大家,具体如下:

方法一:最简单的方法,利用a标签来实现

function parseurl(url){
  var a=document.createelement('a');
  a.href=url;
  return {
   protocol:a.protocol.replace(':',''),
   hostname:a.hostname,
   port:a.port,
   path:a.pathname,
   query:(()=>{
    var query=a.search.substr(1);
    var queryarr=query.split('&');
    var queryobj={};
    queryarr.foreach((item,index)=>{
      var item=item.split('=');
      var key=item[0];
      queryobj[key]=item[1];
    })
    return queryobj;
   })(),
    params:(()=>{
    var params=a.hash.substr(1);
    var paramsarr=params.split('#');
    return paramsarr;
    
   })(),

  }
}
var urlobj = parseurl('http://www.baidu.com:90/search?name=liyajie&age=12#abc#bbb')
console.log(urlobj)

得到的结果

javascript将url解析为json格式的两种方法

方法二:通过nodejs的url模块

解析url需要用到node.js提供的url模块,它使用起来非常简单,通过parse()将一个字符串解析为一个url对象:

  'use strict';
   var url = require('url');
   console.log(url.parse('http://user:pass@host.com:8080/path/to/file?query=string#hash'));

返回的结果

url {
 protocol: 'http:',
 slashes: true,
 auth: 'user:pass',
 host: 'host.com:8080',
 port: '8080',
 hostname: 'host.com',
 hash: '#hash',
 search: '?query=string',
 query: 'query=string',
 pathname: '/path/to/file',
 path: '/path/to/file?query=string',
 href: 'http://user:pass@host.com:8080/path/to/file?query=string#hash' }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。