From 17992a8ff38847414097c0899f86257a0e52f643 Mon Sep 17 00:00:00 2001
From: Tevin <tingquanren@163.com>
Date: Tue, 12 Apr 2022 18:00:20 +0800
Subject: [PATCH] 输入框,增加只读模式

---
 common/Tools.js |   74 ++++++++++++++++++++++++++++--------
 1 files changed, 57 insertions(+), 17 deletions(-)

diff --git a/common/Tools.js b/common/Tools.js
index a7a9a44..6bd9169 100644
--- a/common/Tools.js
+++ b/common/Tools.js
@@ -11,13 +11,14 @@
     /**
      * 显示消息
      * @param msg
+     * @param [duration=2000]
      */
-    static toast(msg) {
+    static toast(msg, duration = 2000) {
         Taro.showToast({
             title: msg,
             icon: 'none',
             mask: true,
-            duration: 2000,
+            duration,
         });
     }
 
@@ -27,7 +28,11 @@
      * @param {String} [search]
      * @return {String|Null}
      */
-    static getUrlParam(name, search = window.location.search) {
+    static getUrlParam(name, search) {
+        if (process.env.TARO_ENV === 'weapp') {
+            return null;
+        }
+        search = search || window.location.search;
         const reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
         const r = search.substr(1).match(reg);
         if (r !== null) {
@@ -61,6 +66,34 @@
                 v = c === 'x' ? r : ((r & 0x3) | 0x8);
             return v.toString(16);
         });
+    }
+
+    /**
+     * 检查网络状态
+     */
+    static checkOnlineState(callback) {
+        // 网页模式
+        if (process.env.TARO_ENV === 'h5') {
+            // 网络已开启
+            if (navigator.onLine) {
+                // 用图片资源测试网络状态
+                const img = new Image();
+                img.onload = () => {
+                    img.onload = null;
+                    callback && callback(true);
+                };
+                img.onerror = () => {
+                    img.onerror = null;
+                    callback && callback(false);
+                };
+                img.src = 'http://test.zhiheiot.com/download/buildArchive/online.png?t=' + Date.now();
+            }
+            // 网络未开启
+            else {
+                callback && callback(false);
+            }
+        }
+        // 补充:小程序模式用 getNetworkType
     }
 
     /**
@@ -118,12 +151,21 @@
     }
 
     /**
+     * 判断是否为未定义
+     * @param {*} data
+     * @return {Boolean}
+     */
+    static isUndefined(data) {
+        return Object.prototype.toString.call(data) === '[object Undefined]';
+    }
+
+    /**
      * 判断是否为 null
      * @param {*} data
      * @return {Boolean}
      */
     static isNull(data) {
-        return data === null;
+        return Object.prototype.toString.call(data) === '[object Null]';
     }
 
     /**
@@ -347,7 +389,7 @@
         if (minutes) {
             words = minutes + '分' + words;
         }
-        const hours = duration.get('hours');
+        const hours = parseInt(duration.as('hours'));
         if (hours) {
             words = hours + '小时' + words;
         }
@@ -360,16 +402,13 @@
      * @return {string}
      */
     static moneyFormat(number) {
-        if (!number && typeof number !== 'number') {
+        if (!number && typeof number !== 'number' && typeof number !== 'string') {
             return '';
         }
         if (typeof number === 'string') {
             number = Number(number) || 0;
         }
-        const numFixed = number.toFixed(2);
-        const integer = parseInt(numFixed);
-        const decimal = numFixed.split('.')[1];
-        return integer.toLocaleString() + '.' + decimal;
+        return number.toFixed(2);
     }
 
     /**
@@ -447,14 +486,15 @@
 
 // h5 中,实现 rem 转换 px
 if (process.env.NODE_ENV === 'development' && process.env.TARO_ENV === 'h5') {
-    const p1 = {
-        x: parseFloat(Taro.pxTransform(10, 750)), y: 10,
-    };
-    const p2 = {
-        x: parseFloat(Taro.pxTransform(1000, 750)), y: 1000,
-    };
     window.rem = val => {
-        const px = (val - p1.x) * (p2.y - p1.y) / (p2.x - p1.x) + p1.y;
+        const p1 = {
+            x: parseFloat(Taro.pxTransform(10, 750)), y: 10,
+        };
+        const p2 = {
+            x: parseFloat(Taro.pxTransform(1000, 750)), y: 1000,
+        };
+        const value = typeof val === 'number' ? val : parseFloat(val);
+        const px = (value - p1.x) * (p2.y - p1.y) / (p2.x - p1.x) + p1.y;
         console.info(Math.round(px) + 'px');
     };
 }
\ No newline at end of file

--
Gitblit v1.9.1