jQuery构建路由

buildMUrl:function( path ,params){
            var url =   "/m" + path;
            var _paramUrl = '';
            if( params ){
                //处理参数
                _paramUrl = Object.keys(params).map(function(k) {
                   return [encodeURIComponent(k), encodeURIComponent(params[k])].join("=");
                }).join('&');
                _paramUrl = "?"+_paramUrl;
            }
            //url到文件的
            //_paramUrl为参数部分的
            return url + _paramUrl

        },

分析:

url构建好了文件部分

Object.keys(params)获取参数的所有的key

map函数进行数组map处理:key与value之间用=连接   各个参数之间用&连接!

进行拼接:url(到文件部分)+param(参数部分)  最后执行join

<!DOCTYPE html>
<html>
<body>
<ul id="ul">
	<li>1</li>
	<li>2</li>
	<li>3</li>
	<li>4</li>
</ul>
</body>
</html>
<script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
<script type="text/javascript">
	$(document).ready(function(){
			var arr = ['a', 'b', 'c'];
             result = Object.keys(arr).map(function(k) {
             		console.log(k);
             		console.log([encodeURIComponent(k), encodeURIComponent(arr[k])].join("="));
                    return [encodeURIComponent(k), encodeURIComponent(arr[k])].join("=");
                }).join('&');

             console.log(result);//0=a&1=b&2=c

            // 每次循环出现一组数字  最后进行拼接join
   			// 0
			// 0=a
			// 
			// 1
			// 1=b
			// 
			// 2
			// 2=c

	})
</script>

整体代码

;
 
var common_ops = {
    init:function(){
        this.eventBind();
        this.setIconLight();
    },
    eventBind:function(){
 
    },
    setIconLight:function(){
        var pathname = window.location.pathname;
        var nav_name = null;
 
        if(  pathname.indexOf("/m/default") > -1 || pathname == "/m" || pathname == "/m/" ){
            nav_name = "default";
        }
 
        if(  pathname.indexOf("/m/product") > -1  ){
            nav_name = "product";
        }
 
        if(  pathname.indexOf("/m/user") > -1  ){
            nav_name = "user";
        }
 
        if( nav_name == null ){
            return;
        }
 
        $(".footer_fixed ."+nav_name).addClass("aon");
    },
    buildMUrl:function( path ,params){
        var url =   "/m" + path;
        var _paramUrl = '';
        if( params ){
            _paramUrl = Object.keys(params).map(function(k) {
                return [encodeURIComponent(k), encodeURIComponent(params[k])].join("=");
            }).join('&');
            _paramUrl = "?"+_paramUrl;
        }
        return url + _paramUrl
 
    },
    buildWwwUrl:function( path ,params){
        var url =    path;
        var _paramUrl = '';
        if( params ){
            _paramUrl = Object.keys(params).map(function(k) {
                return [encodeURIComponent(k), encodeURIComponent(params[k])].join("=");
            }).join('&');
            _paramUrl = "?"+_paramUrl;
        }
        return url + _paramUrl
 
    },
    buildPicUrl:function( bucket,img_key ){
        var upload_config = eval( '(' + $(".hidden_layout_warp input[name=upload_config]").val() +')' );
        var domain = "http://" + window.location.hostname;
        return domain + upload_config[ bucket ] + "/" + img_key;
    },
    notlogin:function( referer ){
        if ( ! referer) {
            alert('授权过期,系统将引导您重新授权');
            referer = location.pathname + location.search;
        }
        window.location.href = this.buildMUrl("/user/bind",{ referer:referer });
    }
};
 
$(document).ready( function() {
    common_ops.init();
});
 
 
// 对Date的扩展,将 Date 转化为指定格式的String
// 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符,
// 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)
// 例子:
// (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423
// (new Date()).Format("yyyy-M-d h:m:s.S")      ==> 2006-7-2 8:9:4.18
Date.prototype.Format = function(fmt)
{ //author: meizz
    var o = {
        "M+" : this.getMonth()+1,                 //月份
        "d+" : this.getDate(),                    //日
        "h+" : this.getHours(),                   //小时
        "m+" : this.getMinutes(),                 //分
        "s+" : this.getSeconds(),                 //秒
        "q+" : Math.floor((this.getMonth()+3)/3), //季度
        "S"  : this.getMilliseconds()             //毫秒
    };
    if(/(y+)/.test(fmt))
        fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length));
    for(var k in o)
        if(new RegExp("("+ k +")").test(fmt))
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));
    return fmt;
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值