From d66ea987a3926731bff1582b2d5d0e90635c9976 Mon Sep 17 00:00:00 2001
From: Tevin <tingquanren@163.com>
Date: Sun, 24 Apr 2022 18:30:10 +0800
Subject: [PATCH] 调整公共样式

---
 forms/textarea/CTextArea.vue |   38 +++++++++++++++++++++++++++++++++-----
 1 files changed, 33 insertions(+), 5 deletions(-)

diff --git a/forms/textarea/CTextArea.vue b/forms/textarea/CTextArea.vue
index 69f97d8..03b27e6 100644
--- a/forms/textarea/CTextArea.vue
+++ b/forms/textarea/CTextArea.vue
@@ -10,21 +10,24 @@
             :name="itemRes.name"
             :title="itemRes.label"
             :required="itemRes.required"
+            :disabled="itemRes.disabled"
             :error="itemRes.error"
         />
         <textarea
             ref="textarea"
             class="textarea"
-            :style="{height: height || '2rem'}"
+            :style="{minHeight: areaHeight, height: areaHeight}"
             :placeholder="placeholder"
             :value="itemRes.formData[itemRes.name]"
-            :autoFocus="true"
+            :autoFocus="false"
+            :autoHeight="true"
             @input="evt=>itemRes.onChange(evt.detail.value)"
         />
     </view>
 </template>
 
 <script>
+import Taro from '@tarojs/taro';
 import { $ } from '@tarojs/extend';
 import { AtInput } from 'taro-ui-vue';
 import './cTextArea.scss';
@@ -35,16 +38,41 @@
         AtInput,
     },
     props: {
-        height: String,
-        placeholder: String,
+        // 表单数据资源(表单组件内部机制专用)
         itemRes: Object,
+        // 文本域输入区域高度
+        height: {
+            type: Number,
+            default: 94,
+        },
+        // 文本雨输入区行数
+        rows: Number,
+        // 占位提示
+        placeholder: String,
     },
     data() {
         return {};
     },
+    computed: {
+        areaHeight() {
+            if (this.rows) {
+                return Taro.pxTransform(this.rows * 40, 750);
+            } else {
+                return Taro.pxTransform(this.height, 750);
+            }
+        },
+    },
     methods: {},
     mounted() {
-        $(this.$refs.input.$el).find('.at-input__input').prepend(this.$refs.textarea.$el);
+        if (process.env.TARO_ENV === 'h5') {
+            $(this.$refs.input.$el)
+                .find('.at-input__input')
+                .prepend(this.$refs.textarea.$el);
+        } else if (process.env.TARO_ENV === 'weapp') {
+            $(this.$refs.input.$el)
+                .find('.at-input__container')
+                .append(this.$refs.textarea);
+        }
     },
 };
 </script>
\ No newline at end of file

--
Gitblit v1.9.1