//swiper var swiper = { init:function () { if ($('.swiper-container').length > 0) { Do('swiper', function () { $('.swiper-container').each(function () { var $option = $(this).data('option'); var id = $(this).attr('id'); $option = helper.parseOptions($option); var option = $option || {}; var defaultOptions = { }; var options = $.extend({}, defaultOptions, option); new Swiper('#'+id,options); }) }); } } }; /*数字加减*/ var alignmentFns = { inputs: [], init: function(input, step, max, min, digit) { var _this = this; input.attr("readonly", "readonly"); //添加左右加减号 input.wrap("
"); input.before(""); input.after(""); //左右调用执行 $("#" + input.attr('id') + "l").click(function() { _this.execute(input, step, max, min, digit, true); }); $("#" + input.attr('id') + "r").click(function() { _this.execute(input, step, max, min, digit, false); }); }, execute: function(input, step, max, min, digit, _do) { var val = parseFloat(this.format(input.val(), digit)); var ori = val; if (_do) val -= step; if (!_do) val += step; if (val < min) { val = min; } else if (val > max) { val = max; } input.val(this.format(val, digit)).change(); }, format: function(val, digit) { if (isNaN(val)) { val = 0; } return parseFloat(val).toFixed(digit); }, // 类型 data: { default_data: { "step": 0.1, "min": 0, "max": 99, "digit": 1 } }, // 初始化 initialize: function() { //使用控件必须有以下属性或者引用alignment类 var inputs = $("input[user_data], input[data-digit], input[data-step], input[data-min], input[data-max],input[data-class], input.alignment"); inputs.each(function() { // 记录原始input代码 alignmentFns.inputs.push(this.outerHTML); //预设值数据选择 var data = alignmentFns.data; var user_data = eval("data." + $(this).attr("user_data")); if (user_data == null) { user_data = JSON.parse(JSON.stringify(data.default_data)); } var digit = $(this).data("digit"); if (digit != null && !isNaN(parseFloat(digit))) { digit = parseFloat(digit).toFixed(0); user_data.digit = parseFloat(digit); } var step = $(this).data("step"); if (step != null && !isNaN(parseFloat(step))) { user_data.step = parseFloat(step); } var min = $(this).data("min"); if (min != null && !isNaN(parseFloat(min))) { user_data.min = parseFloat(min); } var max = $(this).data("max"); if (max != null && !isNaN(parseFloat(max))) { user_data.max = parseFloat(max); } //自动装载 alignmentFns.init($(this), user_data.step, user_data.max, user_data.min, user_data.digit); var data_edit = $(this).data("edit"); if (data_edit) { $(this).attr("readonly", null); } var data_class = $(this).data("class"); if (data_class!='') { $(this).parents(".mc-adjust").addClass(data_class); } }); }, destroy: function() { var inputs = this.inputs; $.each(inputs, function(index, obj) { var input = $(obj)[0]; var id = input.id; $("#" + id + "div").replaceWith(input); }); }, // 动态添加类型 createType: function(types) { $.each(types, function(index, obj) { alignmentFns.data[obj.type] = obj.data; }); } }; //js验证 var valid = { //是否为空 isEmpty: function (str) { return str === "" || str === null || str === undefined; }, //是否为邮件 isEmail: function (str) { var reg = /^\w+((-w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/; if (reg.test(str)) return true; }, //是否为手机号 isMobile: function (str) { var a = /^1\d{10}$/, s = $.trim(str); if (a.test(s)) return true; }, //是否汉字 isCN: function (str) { var s = $.trim(str), reg = /^[\u4e00-\u9fa5]+$/; return reg.test(s); }, //是否密码 isPwd: function (str) { var reg = /^[A-Za-z0-9_-]+$/; if (reg.test(str)) return true; }, //是否为微信号 isWx: function (str) { var rex = /^[a-zA-Z\d_]{5,}$/; return rex.test($.trim(str)); }, //是否全为数字 isNum: function (num) { var rex = /^[0-9]+$/; return rex.test($.trim(num)); }, //是否为热线电话 isPhone: function (num) { var rex = /^[0-9]([0-9]|-)*[0-9]$/; return rex.test($.trim(num)); }, //是否为钱数 isFloat: function (n) { return !isNaN(n); }, //判断是否为url地址 isUrl: function (str) { var rex = /^(http|https){1}:\/\/[^\s]+$/; return rex.test($.trim(str)); }, //判断是否ios isIos:function () { var u = navigator.userAgent; var isIos = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端 return isIos; }, //判断是否安卓 isAndroid:function () { var u = navigator.userAgent; var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1; //android终端 return isAndroid; } }; //通用辅助方法 var helper = { calc: function (arg1, arg2, operator) { var oper = ['+', '-', '*', '/']; // 不合法的运算 if (isNaN(arg1) || isNaN(arg2) || oper.indexOf(operator) < 0) return NaN; // 除以0 if (operator === '/' && Number(arg2) === 0) return Infinity; // 和0相乘 if (operator === '*' && Number(arg2) === 0) return 0; // 相等两个数字相减 if ((arg1 === arg2 || Number(arg1) === Number(arg2)) && operator === '-') return 0; var r1, r2, max, _r1, _r2; try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 } try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 } max = Math.max(r1, r2) _r1 = max - r1; _r2 = max - r2; if (_r1 !== 0) { arg1 = arg1 + '0'.repeat(_r1) } if (_r2 !== 0) { arg2 = arg2 + '0'.repeat(_r2) } arg1 = Number(arg1.toString().replace('.', '')); arg2 = Number(arg2.toString().replace('.', '')); var r3 = operator === '*' ? (max * 2) : (operator === '/' ? 0 : max); var newNum = eval(arg1 + operator + arg2); if (r3 !== 0) { var nStr = newNum.toString(); nStr = nStr.replace(/^-/, ''); if (nStr.length < r3 + 1) { nStr = '0'.repeat(r3 + 1 - nStr.length) + nStr; } nStr = nStr.replace(new RegExp('(\\\d{' + r3 + '})$'), '.$1'); if (newNum < 0) { nStr = '-' + nStr; } newNum = nStr * 1; } return newNum; }, /** * 格式化参数 * @param string */ parseOptions: function (string) { if ($.isPlainObject(string)) { return string; } var start = (string ? string.indexOf('{') : -1), options = {}; if (start != -1) { try { options = (new Function('', 'var json = ' + string.substr(start) + '; return JSON.parse(JSON.stringify(json));'))(); } catch (e) { } } return options; }, json2str: function (json) { return JSON.stringify(json); }, /** * 大数字友好显示 * @param num * @param point * @returns {string} */ tranNumber:function(num, point){ // 将数字转换为字符串,然后通过split方法用.分隔,取到第0个 let numStr = num.toString().split('.')[0]; if(numStr.length<6) { // 判断数字有多长,如果小于6,,表示10万以内的数字,让其直接显示 console.log(numStr); return numStr; }else if(numStr.length>=6 && numStr.length<=8){ // 如果数字大于6位,小于8位,让其数字后面加单位万 let decimal = numStr.substring(numStr.length-4, numStr.length-4+point); console.log(decimal); // 由千位,百位组成的一个数字 return parseFloat(parseInt(num / 10000)+'.'+decimal)+'万' }else if(numStr.length >8){ // 如果数字大于8位,让其数字后面加单位亿 let decimal = numStr.substring(numStr.length-8, numStr.length-8+point); console.log(decimal); return parseFloat(parseInt(num/100000000)+'.'+decimal)+'亿' } }, /** * 刷新页面 * @returns {boolean} */ refresh: function () { window.location.reload(); }, /** * 返回 */ back: function () { window.history.go(-1); }, /** * 跳转 * @param url */ location: function (url) { window.location.href = url; }, /** * 全选 * @param dom */ checkAll: function (dom) { $(dom + " :checkbox").prop("checked", true); }, /** * 反选 * @param dom */ checkOther: function (dom) { $(dom + " :checkbox").each(function () { $(this).prop("checked", !$(this).prop("checked")); }); }, /** * 获取复选款值 * @param dom * @returns {[]} */ getCheckboxValue: function (dom) { var reVal = []; $(dom).find("input[type='checkbox']").each(function () { if ($(this).prop("checked")) { reVal.push($(this).val()); } }); return reVal; }, /** * json数据取指定列数据 * @param json * @param col * @returns array */ json2col: function (json, col) { var len = json.length; var renal = []; if (len == 0) return renal; for (var i = 0; i < len; i++) { renal.push(json[i][col]); } return renal; }, /** * 操作后提示 * @param msg * @param icon * @param callFn * @returns {boolean} */ tips: function (msg, scene, callFn) { var opt = valid.isEmpty(scene) ? 2000 : scene; $.toast(msg, opt,function() { if (typeof (callFn) != "undefined") { callFn(); } }); }, /** * 封装ajax请求 * @param opt */ getAjax: function (opt) { var defaultConfig = { type: 'post', cache: true, async: true, dataType: 'json', beforeSend: function () { //$.showLoading(); //helper.loading('show'); }, error: function () { $.toptip('与服务器断开连接!', 'error'); return false; }, complete: function () { //$.hideLoading(); //helper.loading('hide'); } }; var config = $.extend({}, defaultConfig, opt); $.ajax(config); }, /** * loading * @param $mode * @returns {boolean} */ loading: function ($mode) { var $loadingEl = jQuery('#loading'); $mode = $mode || 'show'; if ($mode === 'show') { if ($loadingEl.length) { $loadingEl.fadeIn(250); } else { $('body').prepend( '
Loading...
' ); } } if ($mode === 'hide') { if ($loadingEl.length) { $loadingEl.fadeOut(250); } } return false; }, /** * 图片懒加载 * @param throttle */ lazy: function (throttle) { var t = throttle || 0; Do('echo', function () { echo.init({ offset: 0, //离可视区域多少像素的图片可以被加载 throttle: t //图片延迟多少毫秒加载 }); }); }, /* 字符串拼接,记得将反斜杠替换为正斜杠 var str = helper.heredoc(function () {\* {@each list as row}
  • ${row.title}
  • {@/each} *\}) */ heredoc: function (fn) { return fn.toString().split('\n').slice(1, -1).join('\n') + '\n' }, /** * 获取url地址栏参数 * @return {string} */ GetQueryString: function (name) { var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); var r = window.location.search.substr(1).match(reg); if (r != null) return unescape(r[2]); return null; }, /** * 判断是否手机 * @returns {boolean} */ checkMobile: function () { var ua = navigator.userAgent; var ipad = ua.match(/(iPad).*OS\s([\d_]+)/), isIphone = !ipad && ua.match(/(iPhone\sOS)\s([\d_]+)/), isAndroid = ua.match(/(Android)\s+([\d.]+)/), isMobile = isIphone || isAndroid; return !!isMobile; }, /** * 获取检索参数name用@隔开,需单独传递参数使用字段@own * @param dom */ getSearchParams: function (dom) { var obj = dom || '#search-form'; var params = {}; var filter = []; if ($(obj).length > 0) { var formData = $(obj).serializeArray(); for (var i = 0; i < formData.length; i++) { var formInfo = formData[i]; var arr = formInfo.name.split('@'); var field = arr[0]; if (arr.length == 1) { //单独传输 params[field] = formInfo.value; } else { filter.push({field: field, op: arr[1], value: formInfo.value}); } } } params.filter = filter; return params; }, /** * ajax分页封装 * @param options * @param dom */ pagination: function (options, dom) { var obj = dom || '#page'; var params = options.params || {}; Do('pagination', function () { var defaultConfig = { locator: 'rows', totalNumberLocator: function (response) { return response.total; }, className: 'paginationjs-theme-primary', pageSize: 20, showGoInput: false, showGoButton: false, autoHidePrevious: true, autoHideNext: true, ajax: { type: 'post', data: params, beforeSend: function () { helper.loading('show'); }, complete: function () { helper.loading('hide'); } } }; var config = $.extend({}, defaultConfig, options); $(obj).pagination(config); }); }, /*下拉加载*/ mescroll: function (dom,options,callback) { /* 手机端去掉多余的end和加载开始 */ $(".mescroll-upwarp").remove(); $(".mescroll-downwarp").remove(); /* 手机端去掉多余的end和加载结束 */ var defaultConfig = { page: {size:20}, auto: true,//初始化完毕,是否自动触发上拉加载的回调 isBoth: false, //上拉加载时,如果滑动到列表顶部是否可以同时触发下拉刷新;默认false,两者不可同时触发; 这里为了演示改为true,不必等列表加载完毕才可下拉; isBounce: false, //此处禁止ios回弹,解析(务必认真阅读,特别是最后一点): http://www.mescroll.com/qa.html#q10 clearEmptyId: dom+'-content', noMoreSize:2, offset: 100, htmlNodata: '

    -- END --

    ', toTop: { //配置回到顶部按钮 src: "/static/jqweui_extend/plugins/mescroll/mescroll-totop.png" //默认滚动到1000px显示,可配置offset修改 } }; var upconfig = $.extend({}, defaultConfig, options); Do('mescroll',function(){ var mescroll = new MeScroll(dom,{up: upconfig}); Do.setData('mescrollInit',mescroll); }); }, renderSize:function (fileSize){ if(null==fileSize||fileSize=='') return "0 Bytes"; var unitArr = ["Bytes","KB","MB","GB","TB","PB","EB","ZB","YB"]; var index=0; var srcsize = parseFloat(fileSize); index=Math.floor(Math.log(srcsize)/Math.log(1024)); var size =srcsize/Math.pow(1024,index); size=size.toFixed(2);//保留的小数位数 return size+unitArr[index]; }, /** * 友好时间显示 * @param timestamp * @returns {string|*} */ dateDiff: function (timestamp) { // 补全为13位 var arrTimestamp = (timestamp + '').split(''); for (var start = 0; start < 13; start++) { if (!arrTimestamp[start]) { arrTimestamp[start] = '0'; } } timestamp = arrTimestamp.join('') * 1; var minute = 1000 * 60; var hour = minute * 60; var day = hour * 24; var halfamonth = day * 15; var month = day * 30; var now = new Date().getTime(); var diffValue = now - timestamp; // 如果本地时间反而小于变量时间 if (diffValue < 0) return '不久前'; // 计算差异时间的量级 var monthC = diffValue / month; var weekC = diffValue / (7 * day); var dayC = diffValue / day; var hourC = diffValue / hour; var minC = diffValue / minute; // 数值补0方法 var zero = function (value) { if (value < 10) return '0' + value; return value; }; // 使用 if (monthC > 12) { // 超过1年,直接显示年月日 return (function () { var date = new Date(timestamp); return date.getFullYear() + '年' + zero(date.getMonth() + 1) + '月' + zero(date.getDate()) + '日'; })(); } else if (monthC >= 1) { return parseInt(monthC) + "月前"; } else if (weekC >= 1) { return parseInt(weekC) + "周前"; } else if (dayC >= 1) { return parseInt(dayC) + "天前"; } else if (hourC >= 1) { return parseInt(hourC) + "小时前"; } else if (minC >= 1) { return parseInt(minC) + "分钟前"; } return '刚刚'; }, /** * 格式化时间戳 * @param timestamp * @param formats * @returns {string} */ dateFormat: function (timestamp, formats) { // formats格式包括 // 1. Y-m-d // 2. Y-m-d H:i:s // 3. Y年m月d日 // 4. Y年m月d日 H时i分 formats = formats || 'Y-m-d'; var zero = function (value) { if (value < 10) return '0' + value; return value; }; if (parseInt(timestamp) === 0) return ''; if (valid.isEmpty(timestamp)) return ''; timestamp = timestamp.toString().length==10?timestamp * 1000:timestamp; var myDate = timestamp ? new Date(timestamp) : new Date(); var year = myDate.getFullYear(); var month = zero(myDate.getMonth() + 1); var day = zero(myDate.getDate()); var hour = zero(myDate.getHours()); var minite = zero(myDate.getMinutes()); var second = zero(myDate.getSeconds()); return formats.replace(/Y|m|d|H|i|s/ig, function (matches) { return ({ Y: year, m: month, d: day, H: hour, i: minite, s: second })[matches]; }); }, /** * 秒数转小时 * @param second * @returns {string} */ getDuration:function (second) { if(valid.isEmpty(second)) return '0:00:00'; var hours = Math.floor(second/3600); var minutes = Math.floor(second/60) % 60; var seconds = Math.floor(second % 60); var time = [helper.PrefixZero(hours,2),helper.PrefixZero(minutes,2),helper.PrefixZero(seconds,2)]; return time.join(':'); }, /** * 自定义函数名:PrefixZero * @param num: 被操作数 * @param n: 固定的总位数 * @return {string} */ PrefixZero:function (num, n) { return (Array(n).join(0) + num).slice(-n); }, /** * 删除行 * @param obj * @param callFn */ delRow: function (obj, callFn) { $(obj).closest('.item-row').remove(); if (typeof callFn != 'undefined') { callFn(obj); } }, /** * 上移 * @param obj */ upMove: function (obj) { var leftMove = $(obj).closest('.item-row'); //当前行 var prevMove = leftMove.prev('.item-row'); //上一个同级元素 if (prevMove.length > 0) { //存在上一个同级元素 prevMove.insertAfter(leftMove); //就把它移动到前面 } }, /** * 下移 * @param obj */ downMove: function (obj) { var rightMove = $(obj).closest('.item-row'); var nextMove = rightMove.next('.item-row'); if (nextMove.length > 0) { nextMove.insertBefore(rightMove); } }, }; //表单辅助方法 var formHelper = { init: function () { this.laydate(); this.number(); this.tags(); this.ckEditor(); this.ace(); this.area(); this.selectpage(); this.h5uploader(); this.inputGroup(); }, /** * 表单提交 * @param opt * @param dom */ subForm: function (opt, dom) { var referrer = document.referrer; var obj = dom || '#form'; var defaultConfig = { btnSubmit: ".btn-sub", btnReset: ".btn-reset", ajaxPost: true, tipSweep: true, label: '.control-label', tiptype: function (msg, o, cssctl) { if (o.type == 3) { //o.obj.closest('.form-group').addClass('has-error'); $.toptip(msg, 'error'); //$(obj).find('.error-msg').show().html(' ' + msg); }/* else { //o.obj.closest('.form-group').removeClass('has-error'); //$(obj).find('.error-msg').html('').hide(); }*/ }, beforeCheck: function (curform) { if (typeof CKEDITOR != 'undefined') { //同步编辑器 for (ck in CKEDITOR.instances) { CKEDITOR.instances[ck].updateElement(); } } }, beforeSubmit: function (curform) { $.showLoading(); $(obj).find('.btn-sub').attr("disabled", "disabled"); //禁用按钮 $(obj).find('.btn-reset').attr("disabled", "disabled"); //禁用按钮 }, callback: function (res) { $.hideLoading(); //var index = parent.layer.getFrameIndex(window.name); $(obj).find('.btn-sub').removeAttr("disabled"); //启用按钮 $(obj).find('.btn-reset').removeAttr("disabled"); //启用按钮 if (res.code == 1) { if (typeof opt == 'function') { opt(res); //parent.layer.close(index); } else { var call = $(obj).data('call') || ''; if (call == "refreshSelfPage") helper.refresh(); if (call == 'url') helper.location(res.url); } } else { $.toptip(res.msg, 'error'); //$(obj).find('.error-msg').show().html(' ' + res.msg); } } }; var config = defaultConfig; if (typeof opt == 'object') { config = $.extend({}, defaultConfig, opt); } Do('valid', function () { $(obj).Validform(config); }); }, copy: function () { Do('copy', function () { var clipboard = new ClipboardJS('.f-copy'); clipboard.on('success', function (e) { layer.msg('拷贝成功'); }); }); }, number: function () { $('.f-number').each(function () { var type = $(this).data('type'); $(this).keyup(function () { if (type == 'number') { $(this).val($(this).val().replace(/[^-\d]/g, '')); } if (type == 'float') { $(this).val($(this).val().replace(/[^-\d.]/g, '')); } }).bind("paste", function () { //CTR+V事件处理 if (type == 'number') { $(this).val($(this).val().replace(/[^-\d]/g, '')); } if (type == 'float') { $(this).val($(this).val().replace(/[^-\d.]/g, '')); } }).css("ime-mode", "disabled"); //CSS设置输入法不可用 }); }, laydate: function () { if ($('.f-laydate').length > 0) { Do('laydate', function () { $('.f-laydate').each(function () { $(this).removeAttr('lay-key'); var opt = $(this).data(); var defaultOption = { elem: this, value:$(this).val(), done: function(value, date, endDate){ if (typeof opt['doneFn'] != 'undefined') { eval(opt['doneFn'] + '($(this),value)'); } } }; var option = $.extend({}, defaultOption, opt); laydate.render(option); }); }); } }, dateDestroy:function(obj){ var inputDate = $(obj).clone(true); $(inputDate).removeAttr("lay-key"); $(obj).after(inputDate); $(obj).remove(); }, selectpage: function () { if ($('.f-selectPage').length > 0) { Do('selectpage', function () { $('.f-selectPage').each(function () { var arrFun = ['formatItem', 'eAjaxSuccess', 'eSelect', 'eOpen', 'eTagRemove', 'eClear']; var opt = $(this).data(); for (var j = 0; j < arrFun.length; j++) { if (opt.hasOwnProperty(arrFun[j])) { var strFun = opt[arrFun[j]]; opt[arrFun[j]] = function (data) { return eval(strFun + '(data)'); }; } } var params = {searchField: opt.showField}; if (opt.hasOwnProperty('params')) params = $.extend({}, params, opt.params); opt.params = function () { return params; }; var defaultOption = { keyField: 'id', showField: 'name', eAjaxSuccess: function (d) { return d ? d : undefined; } }; var option = $.extend({}, defaultOption, opt); $(this).selectPage(option); }); }); } }, ace: function () { if ($('.f-ace').length > 0) { Do('ace', function () { $('.f-ace').each(function (i) { var id = $(this).attr('id'); var data = $(this).data(); var theme = data.theme || 'chrome'; var mode = data.mode || 'html'; var readonly = data.readonly || false; var html = $(this).html(); var editor = ace.edit(id); editor.setOptions({ autoScrollEditorIntoView: true, }); editor.setTheme("ace/theme/" + theme); //设置风格 editor.getSession().setMode("ace/mode/" + mode); //设置语言模式 document.getElementById(id).style.fontSize = '16px'; //设置字体大小 editor.setReadOnly(readonly); //设置编辑器只读 editor.setValue(html); editor.getSession().on("change", function (e) { $("textarea[name='" + id + "']").val(editor.getValue()); }); Do.setData('ace-' + id, editor); }); }) } }, tags: function () { Do('tags', function () { $('.f-tags').tagsinput({ trimValue: true, //去除标签空白 focusClass: 'my-focus-class' }); }); }, area: function () { if ($('.f-area').length > 0) { Do('city', function () { $('.f-area').each(function () { var name = $(this).data('name') || 'area_code'; var inputObj = $(this).find("[name='" + name + "']"); var code = inputObj.val(); var option = $(this).data(); var defaultOption = { code: code, provinceField: 'prov', cityField: 'city', areaField: 'area', required: true, onChange: function (info) { var val = info.code == 0 ? '' : info.code; var area = []; if (!valid.isEmpty(info.province)) area.push(info.province); if (!valid.isEmpty(info.city)) area.push(info.city); if (!valid.isEmpty(info.area)) area.push(info.area); inputObj.val(val); inputObj.attr('area', area.join('/')); if (typeof option['change'] != 'undefined') { eval(option['change'] + '(info,this)'); } } }; var opt = $.extend({}, defaultOption, option); if (code == '' && opt.required == true) { //初始code为空,且必填时补充 inputObj.val('110101'); inputObj.attr('area', '北京市/东城区'); opt.code = '110101'; } $(this).citys(opt); }); }) } }, ckEditor: function () { if ($('.f-ck-editor').length > 0) { Do('ckeditor', 'lrz', function () { $('.f-ck-editor').each(function () { var name = $(this).attr('name'); var $option = $(this).data('option'); var toolbar = $(this).data('toolbar'); if (valid.isEmpty(toolbar)) { var bodyWidth = $(document.body).width(); toolbar = bodyWidth <= 1024 ? 'Basic' : 'Full'; } var option = valid.isEmpty($option) ? {} : $option; var defaultOptions = { toolbar: toolbar }; var options = $.extend({}, defaultOptions, option); var editor = CKEDITOR.replace(name, options); //增加视频按钮 editor.ui.addButton && editor.ui.addButton('html5video', { label: 'Vod', command: 'html5video' }); }); }); } }, h5uploader: function () { if ($('.f-upload').length > 0) { Do('lrz', 'upload', function () { $('.f-upload').each(function () { var _this = $(this); var inputFile = $(_this).find("[type='file']"); var uploadBtn = $(_this).find('.upload-btn'); inputFile.change(function (e) { uploadHelper.funGetFiles(e, _this); }); uploadBtn.click(function () { inputFile.trigger('click'); }); //初始化直在这里设置 var value = _this.data('value') || ''; var theme = _this.data('theme'); var Fun = _this.data('theme-fun') || theme; if (value != '') eval('themeCallfn.' + Fun + '(value,_this)'); }); }) } }, /* * 新封装多行数据 * 增加设置name后的回调 data-setname-after * 增加Add后的回调 data-add-after * 增加Del后的回调 data-del-after */ inputGroup: function () { var groupObj = $('.f-input-group'); if (groupObj.length > 0) { groupObj.each(function () { var that = $(this); var name = that.data('name'); var set_after_fun = that.data('setname-after'); that.find('.item').each(function (index, element) { var _that = $(this); if (index == 0) { _that.find('.btn-del').hide(); _that.find('.btn-add').show(); } else { _that.find('.btn-del').show(); _that.find('.btn-add').hide(); } _that.find('.item-input').each(function (i, v) { var children_name = $(this).data('name'); $(this).attr('name', name + '[' + index + '][' + children_name + ']'); if (typeof set_after_fun != 'undefined') { eval(set_after_fun + '(_that,index,$(this),i)'); } }) }) }) } }, /*增加一行*/ inputGroupAdd: function (obj) { var that = $(obj).closest('.f-input-group'); var html = that.find('.item').eq(0).prop("outerHTML"); var add_after_fun = that.data('add-after'); that.append(html); formHelper.inputGroup(); that.find('.item:last').find('.item-input').each(function () { $(this).val(''); }); if (typeof add_after_fun != 'undefined') { eval(add_after_fun + '(that,$(obj))'); } }, /*删除一行*/ inputGroupDel: function (obj) { var that = $(obj).closest('.f-input-group'); var del_after_fun = that.data('del-after'); $(obj).closest('.item').remove(); formHelper.inputGroup(); if (typeof del_after_fun != 'undefined') { eval(add_after_fun + '(that,$(obj))'); } }, /*上移*/ inputGroupup: function (obj) { var leftMove = $(obj).closest('.item'); //当前行 var prevMove = leftMove.prev('.item'); //上一个同级元素 if (prevMove.length > 0) { //存在上一个同级元素 prevMove.insertAfter(leftMove); //就把它移动到前面 } formHelper.inputGroup(); }, /*下移*/ inputGroupdown: function (obj) { var rightMove = $(obj).closest('.item'); var nextMove = rightMove.next('.item'); if (nextMove.length > 0) { nextMove.insertBefore(rightMove); } formHelper.inputGroup(); }, }; //js数值计算 Number.prototype.calc = function (op, arg) { return helper.calc(this, arg, op); }; juicer.register('json2str', helper.json2str); juicer.register('dateFormat', helper.dateFormat); juicer.register('renderSize', helper.renderSize); juicer.register('getDuration', helper.getDuration);