vxe-form-item中自定义按钮事件触发框

(1)实现效果

(2)具体代码

        html

<vxe-form-item title="设计文档:" field="icon"  span="23">
                <template #default>
                  <!-- 按钮区域 -->
                  <div class="design_file">
                    <div class="design_file_click" @click="handleClick()">
                      <!-- 回显icon -->
                      <div  class="design_file_icon"></div> 
                      <!-- 回显文本内容 -->
                      <div class="design_file_txt">点击调用文件查询框</div>
                    </div>
                    <!-- 右侧按钮 -->
                    <div class="design_file_btn">
                      <vxe-button status="primary" @click="newBuilt()"> 新建 </vxe-button>
                    </div>
                  </div>
                </template>
              </vxe-form-item>

        css

// 设计文档
  .design_file{
    width:100%;
    height:35px;
    line-height:35px;
  }
  // 按钮区域
  .design_file_click{
    width:75%;
    height:35px;
    line-height:35px;
    float:left;
    cursor: pointer;
    border:1px solid #dcdfe6;
     border-radius: 3px;
  }
  // 回显icon
  .design_file_icon{
    max-width:30%;
    height:35px;
    float:left
  }
  // 回显文本内容
  .design_file_txt{
    float:left;
    padding-left: 3%;
    color: rgb(221, 223, 228);
   
  }
  // 鼠标经过
  .design_file_click:hover{
    border: 1px solid #409eff;

  }
  // 右侧按钮
   .design_file_btn{
    width:25%;
    height:35px; 
    float:left;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果在使用 `vxe-form-gather` 和 `vxe-form-item` 组件时,发现元素不实时更新,可能是因为数据没有绑定到 Vue 实例的响应式系统。可以尝试以下几种方法解决该问题: 1. 使用 `v-model` 双向绑定数据。例如: ``` <template> <vxe-form-gather ref="form" :data="formData" @submit="onSubmit"> <vxe-form-item label="姓名"> <input v-model="formData.name" /> </vxe-form-item> <vxe-form-item label="年龄"> <input v-model.number="formData.age" /> </vxe-form-item> </vxe-form-gather> </template> <script> export default { data() { return { formData: { name: '', age: '' } } }, methods: { onSubmit() { console.log(this.formData) } } } </script> ``` 在这个例子,`v-model` 双向绑定了 `formData` 对象的数据,所以当输入的值发生变化时,Vue 会自动更新数据,并使输入的值实时更新。 2. 使用 `$set` 方法手动更新数据。例如: ``` <template> <vxe-form-gather ref="form" :data="formData" @submit="onSubmit"> <vxe-form-item label="姓名"> <input :value="formData.name" @input="updateFormData('name', $event.target.value)" /> </vxe-form-item> <vxe-form-item label="年龄"> <input :value="formData.age" @input="updateFormData('age', $event.target.value)" /> </vxe-form-item> </vxe-form-gather> </template> <script> export default { data() { return { formData: { name: '', age: '' } } }, methods: { updateFormData(key, value) { this.$set(this.formData, key, value) }, onSubmit() { console.log(this.formData) } } } </script> ``` 在这个例子,我们使用 `:value` 绑定了输入的值,然后通过 `@input` 事件来手动更新 `formData` 对象的数据。使用 `$set` 方法更新数据可以将数据添加到 Vue 实例的响应式系统,使其实时更新。 3. 使用 `Object.assign` 方法更新数据。例如: ``` <template> <vxe-form-gather ref="form" :data="formData" @submit="onSubmit"> <vxe-form-item label="姓名"> <input :value="formData.name" @input="updateFormData({name: $event.target.value})" /> </vxe-form-item> <vxe-form-item label="年龄"> <input :value="formData.age" @input="updateFormData({age: $event.target.value})" /> </vxe-form-item> </vxe-form-gather> </template> <script> export default { data() { return { formData: { name: '', age: '' } } }, methods: { updateFormData(data) { this.formData = Object.assign({}, this.formData, data) }, onSubmit() { console.log(this.formData) } } } </script> ``` 在这个例子,我们使用 `Object.assign` 方法更新了 `formData` 对象的数据,将其合并到一个新的对象,然后再将其赋值给 `formData` 对象。这样可以将数据添加到 Vue 实例的响应式系统,使其实时更新。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值