index.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451
  1. export const currentTimeStamp = () => new Date().getTime()
  2. export const unixTimeStamp = (val) => new Date(val).getTime()
  3. export const nextMonth=(year,month,day,bl)=>{
  4. if(day){
  5. }else{
  6. day="01"
  7. }
  8. var str=""
  9. if(month==12){
  10. str= (parseInt(year) +1)+"-01-"+day
  11. }else{
  12. str= year+"-"+(parseInt(month) +1)+"-"+day
  13. }
  14. if(bl){
  15. var now= newDate(str);
  16. return parseUnixTime(new Date(now.getTime()-1000*60*60*24),'{y}-{m}-{d}')
  17. }else{
  18. return str
  19. }
  20. }
  21. // export const nextDay=(year,month,day)=>{
  22. // var now= new Date(year+"-"+month+"-"+day);
  23. // return parseUnixTime(new Date(now.getTime()+1000*60*60*24),'{y}-{m}-{d}')
  24. // }
  25. // 苹果手机时间显示bug
  26. export const newDate = (date) => {
  27. var time=null;
  28. if (date) {
  29. var reg=new RegExp('-','gi')
  30. time=new Date(date.replace(reg,'/'));
  31. }
  32. return time
  33. }
  34. //今天多少天之前的时间
  35. export const beforeTimeStamp = (dayCount,date) => {
  36. if (date) {
  37. var dd = new Date(date);
  38. } else {
  39. var dd = new Date();
  40. }
  41. dd.setDate(dd.getDate() - dayCount)
  42. let time = dd.getTime()
  43. return time
  44. }
  45. //今天多少天之后的时间
  46. export const afterTimeStamp = (dayCount, date) => {
  47. if (date) {
  48. var dd = new Date(date);
  49. } else {
  50. var dd = new Date();
  51. }
  52. dd.setDate(dd.getDate() + dayCount)
  53. let time = dd.getTime()
  54. return time
  55. }
  56. //今天多少年之后的时间
  57. export const afterYearTimeStamp = (yearCount, date) => {
  58. if (date) {
  59. var dd = new Date(date);
  60. } else {
  61. var dd = new Date();
  62. }
  63. dd.setFullYear(dd.getFullYear() + yearCount)
  64. let time = dd.getTime()
  65. return time
  66. }
  67. //计算某日期距当前的时间秒数
  68. export const secondsDistance = (date) => {
  69. var now = new Date().getTime();
  70. date = new Date(date).getTime();
  71. var seconds = parseInt((now - date) / 1000);
  72. return seconds;
  73. }
  74. //计算两个时间的相差天数
  75. export const daysDistance = (date1, date2) => {
  76. date1 = Date.parse(date1);
  77. date2 = Date.parse(date2);
  78. var ms = date2 - date1;
  79. ms = ms < 0 ? 0 : ms;
  80. var days = parseInt(Math.floor(ms / (24 * 3600 * 1000)));
  81. return days;
  82. }
  83. //计算两个时间的相差天数
  84. export const daysDistanceTrue = (date1, date2) => {
  85. date1 = Date.parse(date1);
  86. date2 = Date.parse(date2);
  87. var ms = date2 - date1;
  88. ms = ms < 0 ? -1 : ms;
  89. var days = parseInt(Math.floor(ms / (24 * 3600 * 1000)));
  90. return days;
  91. }
  92. //计算两个时间的相差小时数
  93. export const hourDistanceArr = (date1, date2) => {
  94. if (!date1 || !date2) {
  95. return '-';
  96. }
  97. date1 = Date.parse(date1);
  98. date2 = Date.parse(date2);
  99. var ms = date2 - date1;
  100. ms = ms < 0 ? 0 : ms;
  101. ms = ms / 1000; //s
  102. var Hour = parseInt(Math.floor(ms / (60 * 60)));
  103. var Fen = parseInt(Math.floor(ms % (60 * 60) / 60));
  104. var s = parseInt(Math.floor(ms % (60)));
  105. //600000
  106. return [Hour, Fen, s]
  107. }
  108. //计算两个时间的相差小时数
  109. export const hourDistance = (date1, date2,days) => {
  110. if (!date1 || !date2) {
  111. return '-';
  112. }
  113. date1 = Date.parse(date1);
  114. date2 = Date.parse(date2);
  115. var ms = date2 - date1;
  116. var day = parseInt(Math.floor(ms / (24 * 3600 * 1000)));
  117. ms = ms < 0 ? 0 : ms;
  118. ms = ms / 1000; //s
  119. var Hour = parseInt(Math.floor(ms / (60 * 60)));
  120. var Fen = parseInt(Math.floor(ms % (60 * 60) / 60));
  121. var s = parseInt(Math.floor(ms % (60)));
  122. //600000
  123. var str=""
  124. if(days){
  125. if(day){
  126. str+=(day + '天' )
  127. }
  128. Hour=Hour%24
  129. }
  130. if(Hour){
  131. str+=(Hour + '小时' )
  132. }
  133. if(Fen){
  134. str+=(Fen + '分钟' )
  135. }
  136. if(s){
  137. str+=(s + '秒' )
  138. }
  139. return str;
  140. }
  141. export const parseUnixTime = (time, cFormat) => {
  142. if (arguments.length === 0) {
  143. return null
  144. }
  145. const format = cFormat || '{y}-{m}-{d} {h}:{i}:{s}'
  146. let date
  147. if (typeof time === 'object') {
  148. date = time
  149. } else {
  150. if (('' + time).length === 10) time = parseInt(time) * 1000
  151. date = new Date(time)
  152. }
  153. const formatObj = {
  154. y: date.getFullYear(),
  155. m: date.getMonth() + 1,
  156. d: date.getDate(),
  157. h: date.getHours(),
  158. i: date.getMinutes(),
  159. s: date.getSeconds(),
  160. a: date.getDay()
  161. }
  162. const time_str = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => {
  163. let value = formatObj[key]
  164. if (key === 'a') return ['一', '二', '三', '四', '五', '六', '日'][value - 1]
  165. if (result.length > 0 && value < 10) {
  166. value = '0' + value
  167. }
  168. return value || 0
  169. })
  170. return time_str
  171. }
  172. //微信获取code
  173. export const getWeixinRedirectURI = (appid, url) =>
  174. `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${encodeURIComponent(url)}&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect`
  175. //支付宝获取code
  176. export const getAlipayRedirectURI = (appid, url) =>
  177. `https://openauth.alipay.com/oauth2/publicAppAuthorize.htm?app_id=${appid}&scope=auth_base&redirect_uri=${encodeURIComponent(url)}`
  178. //获取链接的?参数
  179. export const getUrlParam = (name) => {
  180. var k =window.location.href.indexOf("?"+name+"=");
  181. if(k==-1){
  182. k =window.location.href.indexOf("&"+name+"=");
  183. if(k==-1){
  184. return ""
  185. }
  186. }
  187. var reg = new RegExp(name + "=([^&]*)(&|$)");
  188. var r = window.location.href.match(reg);
  189. var strValue = "";
  190. if (r != null) {
  191. strValue = decodeURIComponent(r[1]);
  192. }
  193. return strValue;
  194. }
  195. //将base64图片码转file
  196. export const dataUrlToFile = (dataurl, filename) => {
  197. var arr = dataurl.split(','),
  198. mime = arr[0].match(/:(.*?);/)[1],
  199. bstr = atob(arr[1]),
  200. n = bstr.length,
  201. u8arr = new Uint8Array(n);
  202. while (n--) {
  203. u8arr[n] = bstr.charCodeAt(n);
  204. }
  205. return new File([u8arr], filename, {
  206. type: mime
  207. });
  208. }
  209. //将canvas转换为image的src
  210. export const convertCanvasToImage = (canvas) => {
  211. return canvas.toDataURL("image/png");;
  212. }
  213. //验证身份证
  214. export const checkIdCard = (value) => {
  215. var identNumber = value;
  216. if (identNumber != null) {
  217. identNumber = (identNumber + "").toUpperCase();
  218. }
  219. if (!(/(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(identNumber))) {
  220. return '身份证格式错误';
  221. }
  222. //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。
  223. if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(identNumber))) {
  224. return '身份证格式错误';
  225. }
  226. //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
  227. //下面分别分析出生日期和校验位
  228. var len, re;
  229. len = identNumber.length;
  230. //判断18位身份证号码,现在在国家统一身份证为18位。
  231. if (len == 18) {
  232. re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/);
  233. var arrSplit = identNumber.match(re);
  234. //检查生日日期是否正确
  235. var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
  236. var bGoodDay;
  237. bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) &&
  238. (dtmBirth.getDate() == Number(arrSplit[4]));
  239. if (!bGoodDay) {
  240. return '身份证号码日期不匹配';
  241. } else {
  242. //检验18位身份证的校验码是否正确。
  243. //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
  244. var valnum;
  245. var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
  246. var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
  247. var nTemp = 0,
  248. i;
  249. for (i = 0; i < 17; i++) {
  250. nTemp += identNumber.substr(i, 1) * arrInt[i];
  251. }
  252. valnum = arrCh[nTemp % 11];
  253. if (valnum != identNumber.substr(17, 1)) {
  254. return '身份证号码校验位不正确';
  255. }
  256. return true;
  257. }
  258. } else {
  259. return '身份证号码位数不足';
  260. }
  261. }
  262. // 字符串截取 包含对中文处理,str需截取字符串,start开始截取位置,n截取长度
  263. export const substrMb = (str, start, n) => {
  264. if (str.replace(/[\u4e00-\u9fa5]/g, '**').length <= n) {
  265. return str;
  266. }
  267. let len = 0;
  268. let tmpStr = '';
  269. for (let i = start; i < str.length; i++) { // 遍历字符串
  270. if (/[\u4e00-\u9fa5]/.test(str[i])) { // 中文 长度为两字节
  271. len += 2;
  272. } else {
  273. len += 1;
  274. }
  275. if (len > n) {
  276. break;
  277. } else {
  278. tmpStr += str[i];
  279. }
  280. }
  281. return tmpStr;
  282. }
  283. //验证手机号
  284. export const checkPhone = (value) => {
  285. if (!value) {
  286. return '手机号不能为空';
  287. } else {
  288. const reg = /^1[3-9]\d{9}$/
  289. var result = reg.test(value);
  290. if (result) {
  291. return true;
  292. } else {
  293. return '请输入正确的手机号';
  294. }
  295. }
  296. };
  297. //验证社会信用代码
  298. export const checkCreditCode = (value) => {
  299. if (!value) {
  300. return '社会信用代码不能为空';
  301. } else {
  302. const reg = /^[^_IOZSVa-z\W]{2}\d{6}[^_IOZSVa-z\W]{10}$/g
  303. var result = reg.test(value);
  304. if (result) {
  305. return true;
  306. } else {
  307. return '不是有效的统一社会信用编码';
  308. }
  309. }
  310. };
  311. //是否为微信浏览器
  312. export const isWeiXin = () => {
  313. return /MicroMessenger/.test(window.navigator.userAgent)
  314. }
  315. //获取当前根链接
  316. export const getBaseUrl = () => {
  317. return window.location.href.split("#")[0]
  318. }
  319. //获取指定日期是否在指定时间之间
  320. export const inDateBetwen = (d, d1, d2) => {
  321. //如果时间格式是正确的,那下面这一步转化时间格式就可以不用了
  322. var dateBegin = new Date(d1.replace(/-/g, "/")); //将-转化为/,使用new Date
  323. var dateEnd = new Date(d2.replace(/-/g, "/")); //将-转化为/,使用new Date
  324. //var dateBegin = new Date(d1);//将-转化为/,使用new Date
  325. //var dateEnd = new Date(d2);//将-转化为/,使用new Date
  326. var dateNow = new Date(d.replace(/-/g, "/")); //获取当前时间
  327. var beginDiff = dateNow.getTime() - dateBegin.getTime(); //时间差的毫秒数
  328. var beginDayDiff = Math.floor(beginDiff / (24 * 3600 * 1000)); //计算出相差天数
  329. var endDiff = dateEnd.getTime() - dateNow.getTime(); //时间差的毫秒数
  330. var endDayDiff = Math.floor(endDiff / (24 * 3600 * 1000)); //计算出相差天数
  331. if (endDayDiff < 0) {
  332. //已过期
  333. return false
  334. }
  335. if (beginDayDiff < 0) {
  336. //没到开始时间
  337. return false;
  338. }
  339. return true;
  340. }
  341. //type为字符串类型,有两种选择,"s"代表开始,"e"代表结束,dates为数字类型,不传或0代表本周,-1代表上周,1代表下周
  342. export const getWeekTime = (type, dates) => {
  343. var now = new Date();
  344. var nowTime = now.getTime();
  345. var day = now.getDay();
  346. var longTime = 24 * 60 * 60 * 1000;
  347. var n = longTime * 7 * (dates || 0);
  348. if (type == "s") {
  349. var dd = nowTime - (day) * longTime + n;
  350. };
  351. if (type == "e") {
  352. var dd = nowTime + (7 - day - 1) * longTime + n;
  353. };
  354. dd = new Date(dd);
  355. var y = dd.getFullYear();
  356. var m = dd.getMonth() + 1;
  357. var d = dd.getDate();
  358. m = m < 10 ? "0" + m : m;
  359. d = d < 10 ? "0" + d : d;
  360. var day = y + "-" + m + "-" + d;
  361. return day;
  362. }
  363. export const getDiffDate = (stime, etime) => {
  364. //初始化日期列表,数组
  365. var diffdate = new Array();
  366. var i = 0;
  367. //开始日期小于等于结束日期,并循环
  368. while (stime <= etime) {
  369. diffdate[i] = stime;
  370. //获取开始日期时间戳
  371. var stime_ts = new Date(stime).getTime();
  372. //增加一天时间戳后的日期
  373. var next_date = stime_ts + (24 * 60 * 60 * 1000);
  374. //拼接年月日,这里的月份会返回(0-11),所以要+1
  375. var next_dates_y = new Date(next_date).getFullYear() + '-';
  376. var next_dates_m = (new Date(next_date).getMonth() + 1 < 10) ? '0' + (new Date(next_date).getMonth() + 1) + '-' : (
  377. new Date(next_date).getMonth() + 1) + '-';
  378. var next_dates_d = (new Date(next_date).getDate() < 10) ? '0' + new Date(next_date).getDate() : new Date(next_date).getDate();
  379. stime = next_dates_y + next_dates_m + next_dates_d;
  380. //增加数组key
  381. i++;
  382. }
  383. return diffdate;
  384. }
  385. export const isJSON = (str) => {
  386. if (typeof str == 'string') {
  387. try {
  388. var obj = JSON.parse(str);
  389. if (typeof obj == 'object' && obj) {
  390. return true;
  391. } else {
  392. return false;
  393. }
  394. } catch (e) {
  395. console.log('error:' + str + '!!!' + e);
  396. return false;
  397. }
  398. }
  399. }