ant design vue 踩坑记录

因之前基本在使用antd,这次小小尝试了下ant-design-vue,第一次使用vue3,想记录下。

1.dayjs设置全局中文

  • ConfigProvider是ant design vue中的全局/局部注册的组件;
  • dayjs可以解决日期组件时英文的问题;
<template>
  <a-config-provider :locale="zh_CN">
    <router-view />
  </a-config-provider>
</template>

<script setup>
import zh_CN from "ant-design-vue/es/locale/zh_CN";
import dayjs from "dayjs";
import "dayjs/locale/zh-cn";
dayjs.locale(zh_CN);
</script>

 2.DatePicker设置值时报错

Deprecation warning: value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are discouraged.

  •  错误代码
    const packageDate = ref(null);
    
    onMounted(() => {
      packageDate.value = moment("2023-05-06");
    });

    因设置中文模式时用了dayjs这个插件,导致moment()类型错误

  • 正确代码

  • 所以valueFormat属性必须设置 

  • <template>
        <a-date-picker
           valueFormat="YYYY-MM-DD"
           v-model:value="packageDate"
           class="form-width"
           placeholder="请输入时间"
        />
    </template>
    
    <script>
    
        const packageDate = ref(dayjs);
    
        onMounted(() => {
          packageDate.value = dayjs("2023-05-06");
        });
    
    </script>

3.form表单的双向绑

  • 之前一直用::model="",结果绑定不了,并且提交时获取不到数据,但是用v-model:value=""时,eslint会报错,就以为这样不能用,后来关了eslint可以简单粗暴的解决很多麻烦。
<a-form-item
    label="产品编号"
    name="proNumber"
    :rules="{ required: true, message: '必填项' }"
 >
   <a-input
      v-model:value="stateForm.data.proNumber"
      placeholder="请输入产品编号"
   />
 </a-form-item>

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值