vue 封装公用函数
Vue 函数封装
- 格式化浏览器时间
/**
* 格式化时间
* @param params
* @param blo 默认为true
* @returns {string}
* @constructor 冯刚 2019年6月12日11点01分
*/
function TimeConversion(params,blo=true){
var stamp = Date.parse(params);
var newDate= new Date(stamp);
var year = newDate.getFullYear();
var month = newDate.getMonth() + ;
var date = newDate.getDate();
var h = newDate.getHours();
var m = newDate.getMinutes();
var s = newDate.getSeconds();
if(blo)
return year + '-' + getNow(month) + "-" + getNow(date);
return year + '-' + getNow(month) + "-" + getNow(date) + " " + getNow(h) + ':' + getNow(m) + ":" + getNow(s); } - 校验字符串最后是否存在斜杠
/**
* 验证最后是否有反斜杠
* @param value
* @returns {*}
* @constructor 冯刚 2019年6月12日
*/
function Verification(value) {
if (value.length > && value !== '') {
var str = value.substr(value.length - , );
if (str !== '/' && str !== '') {
value += '/';
}
}
return value;
} - 字符串加密
/**
* 加密
* @param code 要加密的字符串
* @returns {string}
*/
function compileStr(code) {
var c = String.fromCharCode(code.charCodeAt() + code.length);
for (var i = ; i < code.length; i++) {
c += String.fromCharCode(code.charCodeAt(i) + code.charCodeAt(i - ));
}
return escape(c);
} - 字符串解密
/**
* 解密
* @param code 要解密的字符串
* @returns {string}
*/
function uncompileStr(code) {
code = unescape(code);
var c = String.fromCharCode(code.charCodeAt() - code.length);
for (var i = ; i < code.length; i++)
c += String.fromCharCode(code.charCodeAt(i) - c.charCodeAt(i - ));
return c;
} - 根据key获取浏览器地址后参数
/**
* js获取url传递指定参数,解决url中带中文乱码的问题(根据key获取value)
* @param key
* @returns {string|null}
*/
function getQueryString(key) {
var reg = new RegExp("(^|&)" + key + "=([^&]*)(&|$)", "i");
var r = window.location.search.substr().match(reg);
if (r !== null) return decodeURI(r[]); return null;
} - 文本框非空校验,文本框添加红色样式
/**
* 文本框非空验证
* @param type 自定义类型(.或#)
* @param name 页面中自定义类型名称
* @author 冯刚 2019年6月12日
*/
function isNotNull(type, name) {
var temp, select;
var isNull = false;
if (checkValue(type, name))
isNull = true;
temp = type + name;
if (!isNull)
$($(temp)).each(function () {
var _this = $(this);
_this = reductionStyle(_this);
temp = _this.children('input').val();
select = _this.children('div').children('input').val();
if (temp === '' || temp === null) {
isNull = true;
_this.children('input').css('border', 'solid red 1px');
}
if (select === '' || select === null) {
isNull = true;
_this.children('div').children('input').css('border', 'solid red 1px');
}
});
return isNull;
} - 重置初始化样式
/**
* 重置初始化样式
* @param type
* @param name
* @returns {boolean}
*/
function resetStyle(type, name) {
var temp;
var isBool = false;
if (checkValue(type, name))
isBool = true;
temp = type + name;
if (!isBool)
$($(temp)).each(function () {
var _this = $(this);
_this = reductionStyle(_this);
isBool = true;
});
return isBool;
} - 数据封装成 data 对象,并且去除空格
/**
* 封装数据
* @param data 数据对象(用于添加修改)部分可用
*/
function packData(data){
var vmData={};
for (var o in data) {
if (data[o] !== null && data[o] instanceof Array)
vmData[o]=null;
else{
if(typeof data[o] === 'string' && data[o].length > )
vmData[o]=data[o].trim();
else
vmData[o]=data[o];
}
}
return vmData;
} - 动态绑定数据
/**
* 动态赋值(用于查看编辑)
* @param orgObj
* @param newObj
* @returns {*}
* @constructor fg 2019年6月12日
*/
function AssignmentObject(orgObj, newObj){
for (var o in orgObj) {
if (!(orgObj[o] !== null && orgObj[o] instanceof Array))
{
for (var n in newObj){
if(o==n){
orgObj[o]=newObj[n];
break;
}
}
}
}
return orgObj;
} - 清空文本框内容,重置内容
/**
* 按钮重置内容
* @param data
*/
function clearContent(data) {
var v_data = {};
for (var o in data) {
if (data[o] !== null && data[o] instanceof Array)
v_data[o] = data[o];
else {
v_data[o] = null;
}
}
return v_data;
} - 部分函数校验
/**
* 内部引用 还原样式
* @param obj
* @returns {*}
*/
function reductionStyle(obj) {
obj.children('input').css('border', '1px solid #dcdfe6');
obj.children('div').children('input').css('border', '1px solid #dcdfe6');
return obj;
} /**
* 内部引用 检测选择器以及类型名称是否输入全
* @param key
* @param value
* @returns {boolean}
*/
function checkValue(key, value) {
var isBool = false;
if (isCheck(key) && isCheck(value)) {
isBool = true;
alert('请检查选择器类型及名称');
}
if (isCheck(key)) {
isBool = true;
alert('选择器类型不能为空:(./#)');
}
if (isCheck(value)) {
isBool = true;
alert('选择器名称不能为空');
}
return isBool;
} /**
* 内部引用 校验值是否为空
* @param value
* @returns {boolean}
*/
function isCheck(value) {
value = value.trim();
if (value === null || value === '' || value === 'undefined')
return true;
return false;
} - 获取当前时间
/**
* 校验时间
* @param s
* @returns {string}
*/
function getNow(s) {
return s < ? '' + s : s;
} /**
* 获取当前时间
* @returns {string}
*/
function getDate() {
var myDate = new Date();
var year = myDate.getFullYear();
var month = myDate.getMonth() + ;
var date = myDate.getDate();
var h = myDate.getHours();
var m = myDate.getMinutes();
var s = myDate.getSeconds();
return year + '-' + getNow(month) + "-" + getNow(date) + " " + getNow(h) + ':' + getNow(m) + ":" + getNow(s);
}
vue 封装公用函数的更多相关文章
- vue封装公用弹出框方法,实现点击出现操作弹出框
vue封装公用弹出框方法,实现点击出现操作弹出框 如上图所示,这次要实现一个点击出现操作弹框的效果:并将这个功能封装成一个函数,便于在项目的多个地方使用. 具体思路是: 封装一个组件,组件保护一个插槽 ...
- vue防抖节流函数---组件封装,防止按钮多次点击
1.vue 封装utils.js /** * @param {function} func 执行函数 * @param {number} time 防抖节流时间 * @param {boolean} ...
- vue 防抖节流函数——组件封装
防抖(debounce) 所谓防抖,就是指触发事件后在 n 秒内函数只能执行一次,如果在 n 秒内又触发了事件,则会重新计算函数执行时间. 节流(throttle) 所谓节流,就是指连续触发事件但是在 ...
- vue封装插件并发布到npm上
vue封装插件并发布到npm上 项目初始化 首先,要创建项目,封装vue的插件用webpack-simple很合适,vue init webpack-simple 项目名称此命令创建我们的项目的目录, ...
- 浅析vue封装自定义插件
在使用vue的过程中,经常会用到Vue.use,但是大部分对它一知半解,不了解在调用的时候具体做了什么,因此,本文简要概述下在vue中,如何封装自定义插件. 在开始之前,先补充一句,其实利用vue封装 ...
- jQuery编写插件--封装全局函数的插件(一些常用的js验证表达式)
上一篇写到了jQuery插件的3种类型,介绍了第一种类型的写法--封装jQuery对象的方法插件.这一篇要介绍第二种插件类型:封装全局函数的插件:这类插件就是在jQuery命名空间内部添加函数:这类插 ...
- delphi公用函数
{*******************************************************} { } { Delphi公用函数单元 } { } { 版权所有 (C) 2008 } ...
- wemall app商城源码Android之支付宝接口公用函数
wemall-mobile是基于WeMall的Android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之 ...
- 使用promise手动封装ajax函数
最近在做一个单页应用,node和浏览器仅通过json传输数据,因为是只有自己用等于是锻炼一下自己,所以也不用考虑seo的问题,node端我已经写好了,但是浏览器端想要用ajax原生太麻烦,用封装的函数 ...
随机推荐
- 码云因为认证失败导致推送失败 生成 SSH 密钥对
- Ubuntu18.04安装redis-server启动出错
虽然报错原因可能是 redis-server.service: Can't open PID file /var/run/redis/re Aug 26 15:43:25 iZ2ze6ddwhet60 ...
- Java XML文档
概念 XML(EXtensible Markup Language),可扩展标记语言.可扩展就是<>内的东西可以自己定义,可以随便写.标记语言就是加了<>符号的 .HTML是超 ...
- java生成前端验证码+验证「kaptcha」
1.前言 kaptcha是一个非常实用的短信验证码生成工具,通过简单配置即可实现多样化的验证码. 2.引入依赖 <!--第三方验证码--><dependency> < ...
- Scrapy的中间件(一)
中间件是Scrapy里面的一个核心概念.使用中间件可以在爬虫的请求发起之前或者请求返回之后对数据进行定制化修改,从而开发出适应不同情况的爬虫. "中间件"这个中文名字和前面章节讲到 ...
- 第08组 Beta冲刺(3/5)
队名:955 组长博客:点这里! 作业博客:点这里! 组员情况 组员1(组长):庄锡荣 过去两天完成了哪些任务 文字/口头描述 ? 维持进度,检查需求 展示GitHub当日代码/文档签入记录 接下来的 ...
- vultr的防火墙注意事项
如下图所示,你设置让任意IP的TCP,UDP,GRE,ESP,ICMP都允许访问,并不表示开放了任意协议和端口了. 下图只是表示开放了TCP,UDP,GRE,ESP,ICMP五个协议,比如ROS路由的 ...
- linux 系统时间 EST CST
早上本来要做一些实验的,基于时间的.date 查看时间,发现时间不对.用 pool.ntp.org 去同步发现时间还是一样的,并且没有报错.如是开启另外一台时间对的linux服务器进行对比.发现一个是 ...
- java对象转变为map
直接上代码 package com.**.**.**.common; import com.**.**.**.util.JsonUtils; import org.springframework.be ...
- 分布式系统中我们会对一些数据量大的业务进行分拆,分布式系统中唯一主键ID的生成问题
分布式全局唯一ID生成策略 https://www.cnblogs.com/vandusty/p/11462585.html 一.背景 分布式系统中我们会对一些数据量大的业务进行分拆,如:用户表,订 ...