把名称和后台来的json数据约定起来,可以达到的效果就是可以将东西统一化,减少差异,提升模块等的通用性,此后就可以实现具体不同模块内容可以自动或拷贝赋值的方式

2016.7.18 refactor string formatter code:

    String.prototype.format = function () {
var that = this;
var params = arguments;
function applychange(arrayorobject) {
for (var i in arrayorobject) {
var regtoreplace = new RegExp("({)" + i + "(})");
var valtoreplace = arrayorobject[i];
var replacing = function () { return regtoreplace.test(that); }
while (replacing()) {
that = that.replace(regtoreplace, valtoreplace);
}
}
}
applychange(typeof ps[0] !== 'object' ? params : params[0]);
return that;
};

  

another realization, more slim:

    String.prototype.format = function () {
var me = this;
var ps = arguments;
function chg(el) {
for (var i in el) {
var reg = new RegExp("({)" + i + "(})");
var val = el[i];
var ing = function () { return reg.test(me); }
while (ing()) {
me = me.replace(reg, val);
}
}
}
chg(typeof ps[0] !== 'object' ? ps : ps[0]);
return me;
};

  

顺带,这个前端项目中用到的控件,一般是手写,其他类型,比如菜单是  accordion.js这个手风琴控件

note: 关于 {在字符串中的匹配,以""的字符串中,因为\是转义符,"\"是不允许出现的,即在字符串中一定是"\\",所以首先转一次得到\\为字符串的转义符,再+{,即可匹配得到{

(function () {
    "Use Strict";
    String.prototype.format = function (arg) {
        var that = this;
        var args = arguments;
        if (arg instanceof Object && args.length == 1) {
            for (var i in arg) {
                var reg = new RegExp("({" + i + "})");
                while (reg.test(that)) {
                    that = that.replace(reg, arg[i]);
                }
            }
        }
        else {
            for (var i = 0; i < args.length; i++) {
                var reg = new RegExp("({)" + i + "(})");
                var param = args[i];
                while (reg.test(that)) {
                    that = that.replace(reg, param);
                }
            }
        }
        return that;
    }
})();

  

/* File Created: 十二月 18, 2014 
*@Author iGO
*@LastModify 2014-12-19
**/
//使用闭包,为了增加开发效率而写的自动化赋值的类 //todo: string对象 添加公有format方法
(String.prototype.format = function(args) {
    var result = this;
    if (arguments.length > 0) {
        if (arguments.length == 1 && typeof (args) == "object") {
            for (var key in args) {
                if (args[key] != undefined) {
                    var reg = new RegExp("({" + key + "})", "g");
                    result = result.replace(reg, args[key]);
                }
            }
        } else {
            for (var i = 0; i < arguments.length; i++) {
                if (arguments[i] != undefined) {
                    //var reg = new RegExp("({[" + i + "]})", "g");//这个在索引大于9时会有问题,谢谢何以笙箫的指出
                    var regt = new RegExp("({)" + i + "(})", "g");
                    result = result.replace(regt, arguments[i]);
                }
            }
        }
    }
    return result;
})(); //todo:封装的一些公用的小方法
var commonHelper = (function ($, commonHelper) {
    var baseUrl = "http://51creator.vicp.net/cloudants/";     var $id = function (id) { return document.getElementById(id); }
    commonHelper.doNothing = function () { };
    //暂不启用!通用赋值,将所有判断做明确,用一个统一的端口接入,实现所有代码共用一套操作,达到最大复用。减少不同具体模块方法的差异,增加通用性
        commonHelper.applyAlt= function(jsonObject) {
            for (var i in jsonObject) {
                var obj = $id(i);
                var objVal = jsonObject[i];
                //赋值text
                if (obj && !(objVal instanceof Array && obj.innerText)) {
                    $("#" + i).text(jsonObject[i]);
                }
                //赋值图片 图片判断
                if (obj.tagName == "img") {
                    $("#" + i).attr("src", objVal);
                }
                //赋值图表,类型为几种,canvas,内层判断为 按后缀,bar line 和pichart                 //赋值模板
            }
        }     commonHelper.apply = function (jsonObject) {
        if (!jsonObject) return "";
        for (var i in jsonObject) {
            if (document.getElementById(i) && !(jsonObject[i] instanceof Array)) {
                $("#" + i).text(jsonObject[i]);
            }
        }
    }
    commonHelper.applySrc = function (jsonObject) {
        for (var i in jsonObject) {
            if (jsonObject[i].toString().indexOf(".") > -1)
                $("#" + i).attr("src", jsonObject[i]);
        }
    }
    commonHelper.applyChartBar = function (jsonObject) {
        for (var i in jsonObject) {
            if (i.toString().indexOf("_bar") != -1 && document.getElementById(i) != null) {
                var ctx3 = document.getElementById(i).getContext("2d");
                window.myBar3 = new Chart(ctx3).Bar(jsonObject[i], { responsive: true });
            }
        }
    }
    commonHelper.applyChartLine = function (jsonObject) {
        for (var i in jsonObject) {
            if (i.toString().indexOf("_line") != -1 && document.getElementById(i) != null) {
                var ctx2 = document.getElementById(i).getContext("2d");
                window.myLine2 = new Chart(ctx2).Line(jsonObject[i], { responsive: true });
            }
        }
    }
    commonHelper.applyPiChart = function (ret) {
        for (var i in ret) {
            if (document.getElementsByClassName(i).length > 0)
                $("." + i).attr("data-percent", ret[i]).easyPieChart({
                    animate: 1000,
                    size: 100,
                    lineCap: "square",
                    scaleColor: "#ccc",
                    trackColor: "#ddd",
                    barColor: "#0093dd",
                    lineWidth: "3"
                }); ;
        };
    }     commonHelper.applyTemplate = function (el, template) {
        var text = "", args = arguments;
        if (arguments.length >= 2) {
            for (var i = 2; i < arguments.length; i++) {
                var reg = new RegExp("({)" + (i - 2) + "(})", "g");
                template = template.replace(reg, arguments[i]);
            }
        }
        text = template;
        $("#" + el).html(text);
    }     commonHelper.applyTemplate = function (el, template, argArray) {     }     commonHelper.getUrl = function (token) {
        return baseUrl + token;
    }     return commonHelper;
})(jQuery, commonHelper || {}); 模块写法,使用了js模块架构模式中的Module模式
/* File Created: 十二月 9, 2014 */

/*
*Latest Modify:2014-12-12
*Updator:iGO
*login logic 
*
**/ var page351Helper = (function ($, page351Helper, ajaxHelper, commonHelper) {
    "Use Strict";
    var applyStoreInfo_RT = function (ret) {
        ret = ret || { "success": true, "store_lunname": "lun1", "store_errors": "10", "store_alarms": "10" };
        commonHelper.apply(ret);
    }
    var applyStoreCapacity_RT = function (ret) {
        ret = ret || { "success": true, "store_total": "100G", "store_used": "50G", "store_health": "20%" };
        commonHelper.apply(ret);
        $("#store_used").height(ret.store_health);
    }
    var applyStoreFullInfo_RT = function (ret) {
        ret = ret || { "success": true, "store_id": "1", "store_name": "store1", "store_lunlocation": "XXX", "store_type": "XXX", "store_volumespace": "XXX", "store_linkhosts": "8", "store_linkvms": "4", "store_pathsmode": "XXX", "store_allpaths": "18" };
        commonHelper.apply(ret);
    }
    var applyStoreIODelay_RT = function (ret) {
        ret = ret || {};
        commonHelper.applyChartBar(ret);
        commonHelper.apply(ret);
    }
    var applyStoreEntity_RT = function (ret) {
        ret = ret || {};
        commonHelper.apply(ret);
    }     page351Helper.initial = function () {
        //todo:接口:store!getStoreInfo_RT
        ajaxHelper.post({
            url: commonHelper.getUrl("store!getStoreInfo_RT"),
            data: { store_id: "" },
            success: applyStoreInfo_RT
        });
        //todo:接口:store!getStoreCapacity_RT
        ajaxHelper.post({
            url: commonHelper.getUrl("store!getStoreCapacity_RT"),
            data: { store_id: "" },
            success: applyStoreCapacity_RT
        });
        //todo:接口:getStoreFullInfo_RT
        ajaxHelper.post({
            url: commonHelper.getUrl("getStoreFullInfo_RT"),
            data: { store_id: "" },
            success: applyStoreFullInfo_RT
        });
        //todo:接口:store!getStoreIODelay_RT 
        ajaxHelper.post({
            url: commonHelper.getUrl("store!getStoreIODelay_RT"),
            data: { store_id: "" },
            success: applyStoreIODelay_RT
        });
        //todo:接口:store!getStoreEntity_RT
        ajaxHelper.post({
            url: commonHelper.getUrl("store!getStoreEntity_RT"),
            data: { store_id: "" },
            success: applyStoreEntity_RT
        });
    }     return page351Helper; })(jQuery, page351Helper || {}, AJAXHelper, commonHelper);
$(function () {
    page351Helper.initial();
}); [Ps:把有一个需要改进的地方说一下吧,因为这个项目本来前端是分块儿的,所以数据上一般是不重复的,在数据上加了前缀,但是按一般的方法,此处数据映射赋值的时候缺少了context上下文,也就导致可能会出现后面的赋值覆盖掉前面的值,这里最好是配一下context,就是在module的模块上加上接口名称吧,然后映射到页面取值的时候需要在映射器这里取父容器为context的div]

我在一个前端项目中用js整理的一些通用方法,其中使用到的思想,主要就是约定了。的更多相关文章

  1. thinkphp在前端页面的js代码中可以使用 U方法吗? 可以使用模板变量如__URL__等吗?

    thinkphp在前端页面的js代码中可以使用 U方法吗? : 可以的! tp的U方法, 是"全局的", 什么是全局的? 就是, 可以在 "任何地方"使用的: ...

  2. Asp.Net中用JS中操作cookie的方法

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="cookies.aspx.cs& ...

  3. js文件流下载通用方法

    通常我们会用到文件流下载文件,下面给大家一个通用的文件流下载的js /* *下载文件 * options:{ * url:'', //下载地址 * isNewWinOpen:false,是否新窗口打开 ...

  4. js写的一些通用方法

    Js获取当前浏览器支持的transform兼容写法 // 获取当前浏览器支持的transform兼容写法 function getTransfrom() { var transform = '', / ...

  5. javascript功能插件大集合 前端常用插件 js常用插件

    转载来源:https://github.com/jobbole/aw... 包管理器管理着 javascript 库,并提供读取和打包它们的工具.•npm – npm 是 javascript 的包管 ...

  6. 在基于ABP框架的前端项目Vue&Element项目中采用日期格式处理,对比Moment.js和day.js的处理

    Day.js 是一个轻量的处理时间和日期的 JavaScript 库,和 Moment.js 的 API 设计保持完全一样. 如果您曾经用过 Moment.js, 那么您已经知道如何使用 Day.js ...

  7. 前端框架Vue.js——vue-i18n ,vue项目中如何实现国际化

    本项目利用  VueI18n 组件进行国际化,使用之前,需要进行安装 $ npm install vue-i18n 一.框架引入步骤: 1. 先在 main.js 中引入 vue-i18n. // 国 ...

  8. 前端(小程序)项目Aes.js/Md5.js加密的处理方法

    做项目中需要对前端数据加密传输这个时候需要用到前端加密的算法主要是:Aes.js,Md5.js 一.Vue项目用到的aes.js加密. 1.直接在index.html引入aes.js或者在npm in ...

  9. 在Vue&Element前端项目中,使用FastReport + pdf.js生成并展示自定义报表

    在我的<FastReport报表随笔>介绍过各种FastReport的报表设计和使用,FastReport报表可以弹性的独立设计格式,并可以在Asp.net网站上.Winform端上使用, ...

随机推荐

  1. Vuex实践

    本文来自网易云社区 作者:刘凌阳 前言 2017年对于Vue注定是不平凡的一年.凭借着自身简介.轻量.快速等特点,Vue俨然成为最火的前端MVVM开发框架.随着Vue2.0的release,越来越多的 ...

  2. MediaTypeListWidget->insertItem 添加的label没有填充单元格

    label没有填充满当前的item,但是主界面拉伸或者大小变化之后会填充当前的item 类似相关的问题我猜测都是因为子控件或者需要参考的控件的参考对象的大小在初始化的时候还没有完成最终的初始化,导致大 ...

  3. 线段树简单入门 (含普通线段树, zkw线段树, 主席树)

    线段树简单入门 递归版线段树 线段树的定义 线段树, 顾名思义, 就是每个节点表示一个区间. 线段树通常维护一些区间的值, 例如区间和. 比如, 上图 \([2, 5]\) 区间的和, 为以下区间的和 ...

  4. Python全栈 MongoDB 数据库(数据的修改)

    修改操作符的使用   $set 修改一个域的值,增加一个域   阿哲年龄修改为33 db.class1.update({name:'阿哲'},{$set:{age:33}})   如果sex域不存在则 ...

  5. Failed loading D:\Program Files\phpStudy20161103\php\php-5.6.27-nts\ext\php_xdebug.dll

    我用的是phpstudy 更新完composer php 切换composer的国内源的时候老是报找不到\php_xdebug.dll的错误, 原因是, 在php.ini 里面默写就是在Program ...

  6. python进阶训练

    1.列表,字典,集合解析 from random import randint #列表解析,选出大于0的元素 data=[randint(-10,10)for i in range(10)] resu ...

  7. Postmortem Report 第一轮迭代事后分析报告

    一.设想和目标 1.1 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件<BlueZ>是一款全新动作类塔防游戏.与市面上已经存在的塔防游戏不同 ...

  8. MongoDB Linux下的安装和启动

    1. 下载MongoDB,此处下载的版本是:mongodb-linux-i686-1.8.1.tgz.tar. http://fastdl.mongodb.org/linux/mongodb-linu ...

  9. User Agent的学习

    什么是User-Agent? User-Agent是一个特殊字符串头,被广泛用来标示浏览器客户端的信息,使得服务器能识别客户机使用的操作系统和版本,CPU类型,浏览器及版本,浏览器的渲染引擎,浏览器语 ...

  10. iOS-显示日期的转换,今天,昨天,前天

    + (NSString *)stringWithDate:(NSDate *)date{ // 1.获得年月日 NSCalendar *calendar = [NSCalendar currentCa ...