手记

$.extend()方法在前端项目中的应用

应用背景

在实际项目的开发中,特别是数据展示较多的前端界面开发中,为了增强用户的体验,对于数据的操作,我们多用到可视化效果类的图表或者数据插件,比如说图表类的有echarts,highcharts,数据类的有easyui的datagrid之类的东西,熟悉这些插件的朋友就会知道,他们的实现是包含了很多的配置项的:
比如说百度的[echarts][1] 参数配置

option = {
    color: ['#3398DB'],
    tooltip : {
        trigger: 'axis',
        axisPointer : {          
            type : 'shadow'
        }
    },
    grid: {
        left: '3%',
        right: '4%',
        bottom: '3%',
        containLabel: true
    },
    xAxis : [
        {
            type : 'category',
            data : ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
            axisTick: {
                alignWithLabel: true
            }
        }
    ],
    yAxis : [
        {
            type : 'value'
        }
    ],
    series : [
        {
            name:'直接访问',
            type:'bar',
            barWidth: '60%',
            data:[10, 52, 200, 334, 390, 330, 220]
        }
    ]
};

或者easyui的[datagrid][2]配置参数

$('#magazineGrid').datagrid({
    height: 340,
    url: 'url',
    method: 'POST',
    queryParams: { 'id': id },
    idField: '产品ID',
    striped: true,
    fitColumns: true,
    singleSelect: false,
    rownumbers: true,
    pagination: false,
    nowrap: false,
    pageSize: 10,
    pageList: [10, 20, 50, 100, 150, 200],
    showFooter: true,
    columns: [[
        { field: 'ck', checkbox: true },
        { field: '数量', title: '数量', width: 80, align: 'left',
            editor: {
                type: 'numberbox',
                options: {
                    min: 0,
                    precision: 0
                }
            }
        }
    ]],
    onBeforeLoad: function (param) {
    },
    onLoadSuccess: function (data) {

    },
    onLoadError: function () {

    },
    onClickCell: function (rowIndex, field, value) {

    }
});

只要在项目中正确使用这些配置,在项目中就能得到我们想要的结果,运行界面,得到了我们想要的结果,so easy!
然而这样真的就可以了吗?我们常说,代码在设计中一定要考虑到它的扩展性,而这些配置项通过我们直接写来,当在别的界面或者本界面再次运用到这些组件的时候,我们不得不再写一遍,哪怕是简单的复制粘贴.
但粘贴的到的代码虽然可以实现,但代码的扩展性没有体现,并且会出现大量的冗余代码?如果现在在项目中总共有100个图表展示的地方,还有100个数据列表的展示,怎么办?因此,为解决扩展性和冗余性的问题,在代码设计过程中,我们就应当充分考虑到这些可能出现的问题,并做好解决的方案!


$.extend()方法解析

  • $.extend()方法的原型

    extend(result,item1,item2,item3...);

    意思是通过此方法可以将item1,item2,item3等后面若干个配置项合并得到一个新的结果,即第一个参数 result,但是这样会更改result的结构,因此,便有了下面这种方式,(也是我在项目中经常用的方法)!

    var option=$.extend({},src1,src2,src3...)//将空对象"{}"作为结果参数。

    举个栗子

    var result=$.extend({},{name:"天涯123",age:24},{name:"小明",sex:"Boy"});
    //result = {name:"小明",age:24,sex:"Boy"}

    这是一个简单的实例,从上面的结果我们可以得出两个结论:

    1 后面的参数如果和前面的参数存在相同的名称,那么后面的会覆盖前面的参数值.
    2 通过"{}"作为结果参数的方式,其结构不会改变


    项目中的应用(以实现datagrid为例)

    首先,我们知道当前后两个参数相同的时候,后者会覆盖前者,因此,为满足配置项经可能的根据我们自己定义来实现,我们可以定义第一个item(也就是$.extend()中的非第一个参数):

    var basic = {
        title:'My Title',
        iconCls:'icon-save',
        nowrap: true,       
        striped: true,
        border: true,
        fitColumns: true,
        fit:true,
        pagination:true,
        rownumbers:true,
        singleSelect: false,
        loadMsg: '玩命加载中...'
    }

    接着,在我们要实例化一个datagrid数据表格的地方,根据不同配置,来进行个性化定义:

    var config = {
        url:/test/data.json,
        columns: [[
            {field:'ck',checkbox:true},
            {field: 'datetime', title: '日期', align: "center",width:100},
            {field: 'flows', title: '流量', align: "center",width:100}
        ]],
    }

    得到了我们想要的配置config后,我们就要祭出我们的大熔炉extend()方法啦!

    var myOptions = $.extend({},basic,config);
    $("#datagrid").datagrid(myOptions);

    这样只需要通过配置不同情况下的config,就可以得到不同的datagrid数据列表啦!并且我们可以通过封装basic为一个工具文件,在需要应用它 的地方引入他就可以轻松实现实例化,大功告成!


    extend()扩展

    1、$.extend(arg),该方法将arg合并到jquery的全局对象中去

    $.extend({
    hello:function(){window.alert("我是通过extend()合并的全局对象")}
    });

    2、$.fn.extend(arg)该方法将arg合并到jquery的实例对象中去

    $.fn.extend({
    hello:function(){window.alert("我是通过extend()合并的实例对象")}
    });

    3、extend方法重载深拷贝原型

    extend(boolean,result,src1,src2,src3...)

    第一个参数boolean代表是否进行深度拷贝,其余参数和前面介绍的一致!深拷贝的意思我用一个栗子来说明:

    
    var result=$.extend( true,  {},  
    { name: "BS", location: {city: "TIANJIN",county:"CHINA"} },  
    { last: "天崖", location: {state: "ZH",county:"ENGLISH"} } ); 
我们可以看出src1中嵌套子对象location:{city:"TIANJIN"},src2中也嵌套子对象location:{state:"ZH"},深拷贝为true,因此结果是:

result={name:"BS",last:"天崖", location{city:"TIANJIN",state:"ZH",county:"ENGLISH"}}

如果深拷贝为False,则结果是:

result={name:"BS",last:"天崖", location{state:"ZH",county:"ENGLISH"}}


好了,extend()方法就整理到这,么么哒 晚安!
  [1]: http://echarts.baidu.com/demo.html#bar-tick-align
  [2]: http://www.jeasyui.net/demo/331.html
10人推荐
随时随地看视频
慕课网APP