1:url实际应用简介

近期研究发现通过url传递参数很普遍的(淘宝也是这样做的),

通过修改url来传递参数,比如通过关键字搜索某件商品的时候,链接便追加了相应参数。在请求接口的时候直接对url进行解析就行了。我在实际应用中请求结构中page参数结构层级经常发生变化

例如淘宝男装页面是:https://www.taobao.com/markets/nanzhuang/index2016?spm=a219r.lm895.0.0.ADf1F1

当在搜索框中输入英伦时候则变成了以下链接

https://s.taobao.com/list?spm=a217m.8005144.302279.27.1OmJGz&q=%E8%8B%B1%E4%BC%A6&cat=50344007&style=grid&seller_type=taobao 

页面是根据链接来呈现的。通过对&q=%E8%8B%B1%E4%BC%A6&cat=50344007&style=grid&seller_type=taobao这几个参数进行解析,

构造出接口需要的数据,提交给接口。然后根据接口返回数据在页面展现出来。

这样的好处是,如果其他模块也用到参数的话,也可以来解析url中的参数  比如:页码,按照销量筛选,按照地址筛选。

2 url结构

在控制台输入location则出现下面结构:

hash     ""
host           "s.taobao.com"
hostname    "s.taobao.com"
href     "https://s.taobao.com/list?spm=a217m.8005144.302279.27.1OmJGz&q=%E8%8B%B1%E4%BC%A6&cat=50344007&style=grid&seller_type=taobao"
origin    "https://s.taobao.com"
pathname  "/list"
port      ""
protocol    "https:"
search    "?spm=a217m.8005144.302279.27.1OmJGz&q=%E8%8B%B1%E4%BC%A6&cat=50344007&style=grid&seller_type=taobao"

可以在控制台进行一一验证:如 window.location.origin

hash      设置或获取 href 属性中在井号“#”后面的分段。 
host      设置或获取 location 或 URL 的 hostname 和 port 号码。 
hostname    设置或获取 location 或 URL 的主机名称部分。 
href      设置或获取整个 URL 为字符串。 
pathname   设置或获取对象指定的文件名或路径。 
port      设置或获取与 URL 关联的端口号码。 
protocol    设置或获取 URL 的协议部分。 
search    设置或获取 href 属性中跟在问号后面的部分。

3:url操作

3-1 获取当前url完整地址

window.location

location

其他获取方法如下(此处内容参考http://www.jb51.net/article/47288.htm)

document.URL;
document.location;

top.location.href;

parent.document.location;

3-2  只获取hash 等属性则只需要在3-1后面加上相应属性

比如: window.location.origin

3-3 url转换成对象(预留)

   /**
* 分解URL中的参数到JS对象。<br/>
* 将JS对象组装为参数字符串方法参见{@link #queryString}<br/>
* 获得表单内所有元素提交参数字符串表示方法参见{@link #formQuery}
* @param {String} url
* @return {Object} 永远不会为空
*/
dequery: function (url) {
var param = {};
url = url.substr(url.indexOf('?') + 1);
if (url) {
url = url.split('&');
for (var i = 0, len = url.length; i < len; i++) {
var arr = url[i].split('=');
param[arr[0]] = decodeURIComponent(arr[1]);
}
}
return param;
},

3-4 对象转换成url

 /**
* 返回对象查询字符串表示形式.
* <pre><code>
var obj = {name:'Exiu', age:'25'}; //显示 name=Exiu&age=25
alert(queryString(obj));
// 也可以双重键值对形式
{"doAction":"interView","extra_params":{"interview_id":"27"}}
=> 'doAction=interView&extra_params['interview_id']=27'
* </code></pre>
* 提取url参数转为JS对象方法参见{@link #dequery}<br/>
* 获得表单内所有元素提交参数字符串表示方法参见{@link #formQuery}
* @param {Object} obj
* @return {String} 对象的查询字符串表示形式
*/
queryString: function (obj) {
if (!obj)
return '';
var arr = [];
for (var k in obj) {
var ov = obj[k], k = encodeURIComponent(k);
var type = typeof ov;
if (type === 'undefined') {
arr.push(k, "=&");
} else if (type != "function" && type != "object") {
arr.push(k, "=", encodeURIComponent(ov), "&");
} else if (ov instanceof Array) {
if (ov.length) {
for (var i = 0, len = ov.length; i < len; i++) {
arr.push(k, "=", encodeURIComponent(ov[i] === undefined ? '' : ov[i]), "&");
}
} else {
arr.push(k, "=&");
}
} else if (type === 'object') {
// 例如"extra_params":{"interview_id":"27"}形式
for (var kk in ov) {
arr.push(k, '[', kk, ']', '=', encodeURIComponent(ov[kk]), '&');
}
}
}
arr.pop();
return arr.join("");
}

3-4 url修改单个参数

3-5 url修改多个参数

我现在做的功能展示中需要  对分页,关键字,地区,商品分类,店铺类别,时间顺序,好评顺序 这个几个因素

根据实际场景构造数据请求借口

  //根据传入参数更改链接,如果链接中有page,应去掉page参数,
goUrl: function (name,value) {
var urlObj = Util.dequery(location.href); if(urlObj.page){
delete urlObj.page;
}
urlObj[name]=value;
var urlStr =Util.queryString(urlObj);
location.href = '?' + urlStr;
}

url操作一网打尽(一)的更多相关文章

  1. js原生的url操作函数,及使用方法。(附:下边还有jquery对url里的中文解码函数)

    js原生的url操作函数,完善的. /*****************************/ /* 动态修改url */ /*****************************/ var ...

  2. MT写的对URL操作的两个方法

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. jstl--->Core 核心标签库->URL操作

    jstl--->Core 核心标签库->URL操作 -->import.param.URL.redirect <c:import>将静态或动态文件包含至本身jsp页面 而 ...

  4. URL操作

    ThinkPHP 的 URL 操作.主要涉及到 URL 路径大小写.伪静态.生成以及模版中的 U()方法. 一.URL大小写 系统默认的规范是根据 URL 里面的模块名.控制器名来定位到具体的控制器类 ...

  5. [原创]java WEB学习笔记43:jstl 介绍,core库详解:表达式操作,流程控制,迭代操作,url操作

    本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...

  6. jQuery 工具类函数-URL操作函数

    调用名为$. param的工具函数,能使对象或数组按照key/value格式进行序列化编码,该编码后的值常用于向服务端发送URL请求,调用格式为: $. param (obj); 参数obj表示需要进 ...

  7. php 对url 操作类:url拼接、get获取页面、post获取页面(带传参)

    /* * @brief url封装类,将常用的url请求操作封装在一起 * */ class URL{ private $error; public function __construct(){ $ ...

  8. PHP 路径或URL操作

    echo 'documentroot:'.$_SERVER['DOCUMENT_ROOT'].'<br>'; //根目录,在apache的配置文件里定义:httpd.conf 比如:Doc ...

  9. 打开URL操作

    /* * 打开 url 的两种方法 */ public class OpenUrl { public static void main(String[] args) { String url = &q ...

随机推荐

  1. JavaScript 执行环境(执行上下文) 变量对象 作用域链 上下文 块级作用域 私有变量和特权方法

    总结自<高程三>第四章  理解Javascript_12_执行模型浅析   JS的执行环境与作用域  javascript高级程序第三版学习笔记[执行环境.作用域] 在javascript ...

  2. struts2.3 创建工程

    1:在该网站下载struts2.3.16.3,目前为最新版.http://www.struts.apache.org/download.cgi 不妨下载“Full Distribution”版本 下载 ...

  3. php 常用的调试方法

    file_put_contents("c:\1.log","输出字符串",FILE_APPEND);第三个参数是防止前面的内容被覆盖 error_log(pri ...

  4. 分布式版本控制系统Git-----1.Git 初识

    开始工作咯,师傅让我开始学习Git.刚接触我是懵逼的,"分布式版本控制系统"啥玩意啊这是,大家可不能从字面意思上理解啊,刚开始,版本控制么,我以为是团队合作的时候把开发工具.JDK ...

  5. Apache Http Server和Tomcat 之区别

    转自:Apache Http Server和Tomcat 之区别 Apache官方网站:http://www.apache.org/Tomcat官方网站:http://tomcat.apache.or ...

  6. 再谈Java方法传参那些事

    把一个变量带进一个方法,该方法执行结束后,它的值有时会改变,有时不会改变.一开始会觉得--“好神奇呀”.当我们了解java内存分析的知识后,一切都是那么简单明了了--“哦,这么回事呀”.但是今天的上机 ...

  7. [ An Ac a Day ^_^ ] CodeForces 691F Couple Cover 花式暴力

    Couple Cover Time Limit: 3000MS   Memory Limit: 524288KB   64bit IO Format: %I64d & %I64u Descri ...

  8. amazeui 搜索 动态

    <!doctype html> <html class="no-js"> <head> <meta charset="utf-8 ...

  9. 缓存HA的开源解决方案

    1) Twitter的Redis/Memcached代理服务:Twemproxy 2) Facebook的Memcached协议路由器:McRouter 3) Youtube的Mysql中间件:Vit ...

  10. APP测试--功能测试

    1.1 了解需求 这一点,不但是功能测试,是所有测试都需要的第1步.通过需求文档,与产品经理的沟通,与开发的沟通,用户的使用习惯等各方法,了解APP的需求. 1.2 编写测试用例 当然之前可能是测试计 ...