厦门机器猫 2022-11-24 09:14 采纳率: 50%
浏览 9
已结题

schema2code

问题遇到的现象和发生背景

在使用schame2code自动生成代码的时候,生成的edit.vue界面提交表单的时候提示docId必须为字符串或者数字

用代码块功能插入代码,请勿粘贴截图
<template>
  <view class="uni-container">
    <uni-forms ref="form" :model="formData" validate-trigger="submit" err-show-type="toast">
      
     
      <uni-forms-item name="drug_name" label="药品名称" required>
        <uni-easyinput v-model="formData.drug_name"></uni-easyinput>
      </uni-forms-item>
    
      <uni-forms-item name="salenum" label="销售数量">
        <uni-easyinput type="number" v-model="formData.salenum"></uni-easyinput>
      </uni-forms-item>
      <uni-forms-item name="salePrice" label="销售单价">
        <uni-easyinput v-model="formData.salePrice"></uni-easyinput>
      </uni-forms-item>
      <uni-forms-item name="saledata" label="销售日期">
        <uni-datetime-picker return-type="timestamp" v-model="formData.saledata"></uni-datetime-picker>
      </uni-forms-item>
      <view class="uni-button-group">
        <button type="primary" class="uni-button" @click="submit">提交</button>
      </view>
    </uni-forms>
  </view>
</template>

<script>
  import { validator } from '../../js_sdk/validator/data.js';

  const db = uniCloud.database();
  const dbCollectionName = 'data';

  function getValidator(fields) {
    let result = {}
    for (let key in validator) {
      if (fields.indexOf(key) > -1) {
        result[key] = validator[key]
      }
    }
    return result
  }

  

  export default {
    data() {
      let formData = {
        "drug_type": "",
        "view": null,
        "drug_name": "",
        "supplier": "",
        "buyPrice": "",
        "buynum": null,
        "buydate": null,
        "firstdata": null,
        "lastdata": null,
        "salenum": 0,
        "salePrice": "",
        "saledata": null
      }
      return {
        formData,
        formOptions: {
          "drug_type_localdata": [
            {
              "text": "中药",
              "value": "中药"
            },
            {
              "text": "西药",
              "value": "西药"
            },
            {
              "text": "中西结合",
              "value": "中西结合"
            }
          ]
        },
        rules: {
          ...getValidator(Object.keys(formData))
        }
      }
    },
    onLoad(e) {
      if (e.id) {
        const id = e.id
        this.formDataId = id
        this.getDetail(id)
      }
    },
    onReady() {
      this.$refs.form.setRules(this.rules)
    },
    methods: {
      
      /**
       * 验证表单并提交
       */
      submit() {
        uni.showLoading({
          mask: true
        })
        this.$refs.form.validate().then((res) => {
          return this.submitForm(res)
        }).catch(() => {
        }).finally(() => {
          uni.hideLoading()
        })
      },

      /**
       * 提交表单
       */
      submitForm(value) {
        // 使用 clientDB 提交数据
        return db.collection(dbCollectionName).doc(this.formDataId).update(value).then((res) => {
          uni.showToast({
            icon: 'none',
            title: '修改成功'
          })
          this.getOpenerEventChannel().emit('refreshData')
          setTimeout(() => uni.navigateBack(), 500)
        }).catch((err) => {
          uni.showModal({
            content: err.message || '请求服务失败',
            showCancel: false
          })
        })
      },

      /**
       * 获取表单数据
       * @param {Object} id
       */
      getDetail(id) {
        uni.showLoading({
          mask: true
        })
        db.collection(dbCollectionName).doc(id).field("drug_type,view,drug_name,supplier,buyPrice,buynum,buydate,firstdata,lastdata,salenum,salePrice,saledata").get().then((res) => {
          const data = res.result.data[0]
          if (data) {
            this.formData = data
            
          }
        }).catch((err) => {
          uni.showModal({
            content: err.message || '请求服务失败',
            showCancel: false
          })
        }).finally(() => {
          uni.hideLoading()
        })
      }
    }
  }
</script>

<style>
  .uni-container {
    padding: 15px;
  }

  .uni-input-border,
  .uni-textarea-border {
    width: 100%;
    font-size: 14px;
    color: #666;
    border: 1px #e5e5e5 solid;
    border-radius: 5px;
    box-sizing: border-box;
  }

  .uni-input-border {
    padding: 0 10px;
    height: 35px;

  }

  .uni-textarea-border {
    padding: 10px;
    height: 80px;
  }

  .uni-button-group {
    margin-top: 50px;
    /* #ifndef APP-NVUE */
    display: flex;
    /* #endif */
    justify-content: center;
  }

  .uni-button {
    width: 184px;
  }
</style>


运行结果及报错内容

[本地调试]SYSTEM_ERROR:docIdb必须为字符串或者数字

  • 写回答

0条回答 默认 最新

    报告相同问题?

    问题事件

    • 系统已结题 12月2日
    • 专家修改了标签 11月24日
    • 创建了问题 11月24日

    悬赏问题

    • ¥15 安卓adb backup备份应用数据失败
    • ¥15 eclipse运行项目时遇到的问题
    • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
    • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
    • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
    • ¥50 成都蓉城足球俱乐部小程序抢票
    • ¥15 yolov7训练自己的数据集
    • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
    • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
    • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)