js处理url中的请求参数(编码/解码)

  在处理 a 链接跳转其他页面时,总会遇到需要传递一些当前页面的信息到其他页面,然后其他页面利用这些信息进行相关操作。利用 get 请求或 hash 传递是常见的方式。

  首先,需要对传递的参数进行编码,保证数据的安全性;之后,将参数拼接到要跳转的url后,并设置为 a 链接中的 href 属性值。

var util = {
    setUrlParam: function (params, targetUrl) {
        var url = ‘‘;
        if(params && targetUrl){
            // json系列化为字符串,并编码
            var enRequestParams = encodeURIComponent(JSON.stringify(params));
            // get拼接
            url = targeteUrl + ‘?rq=‘ + enRequestParams;
            // 或hash拼接
            // targeteUrl = targeteUrl + ‘#rq=‘ + enRequestParams;
        }
        return url;
    }
}
// 假设需要传递的数据如下
var requestParams = {
    ‘id‘: ‘1001‘,
    ‘time‘: ‘2017-04-21‘
};
// 要跳转的页面url
var targeteUrl = ‘http://www.baidu.com‘;

// 获取html中id=target的a链接,并设置href
var ndTargetLink = document.querySelector(‘a#target‘);
ndTargetLink.href = util.setUrlParam(requestParams, targeteUrl);

  完成了地址拼接,接下来就是在目标页面中解析请求参数了。

var util = {
    // 获取参数
    getUrlParam:function(url, param) {
      var reg = new RegExp(param + "=([^&]*)(&|$)");
      var num = url.match(reg);
      if (num != null)
        return num[1];
      return null;
    },
    // 解码,try处理多次编码的情况
    decodeUrl:function(str){
        str=decodeURIComponent(str);
        var json=null;
        try{
            json=JSON.parse(str);
            return json;
        }catch(e){
            return  util.decodeUrl(str);
        }
    }
}
var loadPage = {
    data:(function(){
       var json=util.decodeUrl(util.getUrlParam(hash,‘rq‘));
       return json;
    })()
}
var data = loadPage.data;
console.log(‘data‘,data);

 

时间: 2024-08-11 01:19:13

js处理url中的请求参数(编码/解码)的相关文章

js的url中传递中文参数乱码,如何获取url中参数问题

一:Js的Url中传递中文参数乱码问题,重点:encodeURI编码,decodeURI解码: 1.传参页面Javascript代码: <script type=”text/javascript”> function send(){ var url = "test01.html"; var userName = $("#userName").html(); window.open(encodeURI(url + "?userName="

使用JS替换URL中的指定参数

现有一个URL: http://abcccc.com/blog?query_key=name&query_value=abc 想要替换其中的参数:query_key,用JS该怎么做呢? 这里记录一种方案: var key = ‘title‘; var value = ‘defg‘; var currentURL = http://www.561.cn/blog?query_key=name&query_value=abc; var targetURL = ‘‘; if ((currentU

node.js获取url中的各个参数

实例代码test.js var http=require('http'); var url=require('url'); var querystring=require('querystring'); http.createServer(function(request, response) { var urlStr = request.url; var methodName = urlStr.substring(1, urlStr.indexOf('?')); console.log('me

JS获取url中的指定参数

function GetRequest() { var url = location.search; //获取url中"?"符后的字串 var theRequest = new Object(); if (url.indexOf("?") != -1) { var str = url.substr(1); strs = str.split("&"); for(var i = 0; i < strs.length; i ++) { t

JS获取URL中的GET参数

方法一: function getLocationVal(id){    var temp = location.search.split(id+"=")[1] || "";    return temp.indexOf("&")>=0 ? temp.split("&")[0] : temp; } 方法二:: function getArgs(){ var args = {}; var match = n

js获取URL中的参数

js获取URL中的一些参数的意思 location对象 含有当前URL的信息. 属性 href 整个URL字符串. protocol 含有URL第一部分的字符串,如http: host 包含有URL中主机名:端口号部分的字符串.如//www.cenpok.net/server/ hostname 包含URL中主机名的字符串.如http://www.cenpok.net ; port 包含URL中可能存在的端口号字符串. pathname URL中"/"以后的部分.如~list/inde

js获取url中的参数,并保证获取到的参数不乱码

  //网上比较经典的js获取url中的参数的方法  function getQueryString(name) {      var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");      var r = window.location.search.substr(1).match(reg);      if ( r != null ){        

如何自动识别判断url中的中文参数是GB2312还是Utf-8编码?

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Web;using System.Text.RegularExpressions; namespace ConsoleApplication2 {        class Program {                public static string DecodeURL2(String uriS

JS获取URL中参数值(QueryString)的4种方法分享

http://www.jb51.net/article/48942.htm JS获取URL中参数值(QueryString)的4种方法分享 作者: 字体:[增加 减小] 类型:转载 今天碰到要在一个页面获取另外一个页面url传过来的参数,一开始很本能的想到了用 split("?")这样一步步的分解出需要的参数.后来想了一下,肯定会有更加简单的方法的!所以在网上找到了几个很又简单实用的方法,mark下. 方法一:正则法 复制代码 代码如下: function getQueryString