js的方法重构

相当于java中方法的重写,会覆盖以前的方法

定义js的基元

var EditView = function(){
    var _this = null;
    var $id = null;
    var key = null;
    var $submit_form = $("#submit_form");
    var $url = "notification/notificationtype";
    var type = null;
    var $add = null;
    var $getById = null;
    var $upd = null;
    this.url = null;
    this.dicurl = "system/dic/getDicByCode/";
    this.uploadUrl = getUploadUrl();
    this.createCusView = null;
    this.getMainData = null;
    this.init = function(){
        key = $.util.request[$id];
        type = $.util.request["type"];
        _this = this;
        $Core.OnPageLoad(function () {
            $Core.Loading.HidePageLoading();
        });
        if (key&&key!="") {
            var url = $url+"/getById/" + key;
            if($getById != null && $getById != "" && $getById != "null"){
                url = $getById+"/"+key;
            }
            $.get(url, function (data) {
                _this.getMainData = data;
                $submit_form.form("load", data.data);
                if(type=="red"){
                    $submit_form.form("load", data.data);
                    $("input").attr("readonly", "readonly");
                    $(".easyui-combobox").combo('readonly', true);
                    $(".easyui-combotree").combotree('readonly', true);
                    $('.easyui-textbox').textbox('readonly');
                    $(".easyui-my97").my97('disable');
                    $("#btnSave").hide();
                    $("button").hide();
                    /*$("input",$submit_form).each(function(i,n) {
                        $(n).textbox('disable');
                    });*/
                }
                if(type != "add" && _this.renderSelectors){
                	for(var i=0,len=_this.renderSelectors.length; i<len; i++){
                		var renderSelector = _this.renderSelectors[i],
                			dictDatas = $Core.DicCache.get(renderSelector.settings.dictCode);
                			renderSelector.echoSelect(data, dictDatas);
                	}
                }
            });
            // var time = setTimeout(function(){
            //     if(_this.createCusView){
            //         _this.createCusView();
            //     }
            //     clearTimeout(time);
            // },300);
        }
        // else{
        //     if(_this.createCusView){
        //         _this.createCusView();
        //     }
        // }
        if(_this.createCusView){
            _this.createCusView();
        }
        $("#btnSave").click(function () {
            if ($submit_form.form("validate")) {
                var url = $url+"/add";
                if($add != null && $add != "" && $add != "null") {
                    url = $add;
                }
                if (key && key != ""){
                    url = $url+"/upd";
                    if ($upd != null && $upd != "" && $upd != "null"){
                        url = $upd;
                    }
                }

                var paras = $submit_form.serialize();
                $.post(url, paras, function (data) {
                    if (data.code == 0) {
                        $Core.UI.message.success("保存成功!");
                    }
                    else {
                        $Core.UI.message.error(data.msg);
                    }
                });
            }
        });
    }

    function getUploadUrl() {
        var serviceUrl = $Core.SERVICEPATH();
        var preffix = serviceUrl.substring(0,serviceUrl.lastIndexOf("cnten"));
        var uploadUrl = preffix + "/plugs/attachment/fileUpload";
        return uploadUrl;
    }
};

重构基元中的init方法,不重写会继续调用基元的init方法

var _self = new EditView();
$(function () {
    _self.createCusView = function(){
    	$("#approveState").combobox({
            url: _self.dicurl+'planState'
        });
 }
    
/*    _self.init = function(e){
    	debugger;
        key = $.util.request["installApplyId"];
        type = $.util.request["type"];
        _this = this;
        $Core.OnPageLoad(function () {
            $Core.Loading.HidePageLoading();
        });
        if (key&&key!="") {
            $.get("security/installapplyvo/getById/" + key, function (data) {
            	debugger;
                _this.getMainData = data;
                $("#submit_form").form("load", data.data);
                
                if(type=="red"){
                    $("input").attr("readonly", "readonly");
                    $(".easyui-combobox").combo('readonly', true);
                    $(".easyui-my97").my97('disable');
                    $(".easyui-combotree").combotree('readonly', true);
                    $("#btnSave").hide();
                    $("button").hide();
                   
                }
                if(type=="edit"){
                   
                }
            });
        }
        if(_this.createCusView){
            _this.createCusView();
        }
    }*/
    
    _self.init();
});

 

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在JavaScript中,map()方法可以用于重构数组。map()方法遍历数组并在遍历过程中处理数组元素,返回一个新的数组,而原始数组保持不变。我们可以使用map()方法将原始数组的每个元素进行处理,并返回一个新的包含处理后元素的数组。 下面是一个使用map()方法重构数组的示例代码: ```javascript // 使用map重构数组,将数组中的每个元素平方 var arr = [1, 2, 3, 4, 5]; var arr1 = arr.map(function(item) { return item * item; }); console.log(arr1); // [1, 4, 9, 16, 25] ``` 在这个例子中,我们定义了一个原始数组arr,使用map()方法对每个元素进行平方操作,并将结果存储在新的数组arr1中。最后,我们通过打印arr1来验证结果。 另外,我们还可以自定义一个array_map()函数,使用类似于map()方法的方式实现数组的重构。下面是一个使用array_map()函数重构数组的示例代码: ```javascript // array_map函数实现数组重构 function array_map(arr, fn) { var arr1 = []; for (var i = 0; i < arr.length; i++) { if (i in arr) arr1[i = fn(arr[i], i, arr); } return arr1; } var arr = [1, 2, 3, 4, 5]; var arr2 = array_map(arr, function(item, index, arr) { return item * item; }); console.log(arr2); // [1, 4, 9, 16, 25] ``` 在这个例子中,我们定义了一个array_map()函数,它接受一个数组和一个回调函数作为参数。函数内部使用for循环遍历数组,对每个元素应用回调函数并将结果存储在新的数组arr1中。最后,我们通过打印arr2来验证结果。 总之,使用map()方法或自定义的array_map()函数都可以实现数组的重构,可以根据具体的需求选择适合的方法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wespten

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值