Vue3(h5)封装电子签名组件

基于vue3-signature封装电子签名组件(复制即可使用)

下载插件
npm install vue3-signature --save-dev
全局注入

在main.ts文件中

import { createApp } from "vue";
import App from "./App.vue";
import Vue3Signature from "vue3-signature";
import "vant/es/toast/style";

const app = createApp(App);

app.use(Vue3Signature).mount("#app");
封装组件

components/signature/index.ts

<template>
  <div class="signature">
    <Vue3Signature
      ref="signature"
      :sigOption="state.option"
      :h="props.height"
      :disabled="props.disabled"
      class="canvas"
    />
    <van-space class="action" v-if="!props.disabled">
      <van-button size="small" @click="undo">撤销</van-button>
      <van-button size="small" @click="clear">清除</van-button>
      <van-button type="primary" size="small" @click="save(props.imageType)"
        >保存</van-button
      >
    </van-space>
  </div>
</template>

<script setup lang="ts">
import { reactive, ref } from "vue";

/**
 *  参数名            类型                  描述
 *  height          String               画布高度
 *  imageType       String               图片类型
 *  disabled        Boolean              是否禁用画布
 */

const props = defineProps({
  height: {
    type: String,
    default: "11.25rem"
  },
  imageType: {
    type: String,
    default: "image/png"
  },
  disabled: {
    type: Boolean,
    default: false
  }
});

const emit = defineEmits(["image-value"]);

const state = reactive({
  option: {
    penColor: "rgb(0, 0, 0)",
    backgroundColor: "rgb(255,255,255)"
  }
});

const signature = ref();

const save = (t: any) => {
  emit("image-value", signature.value.save(t), "save");
};

const clear = () => {
  signature.value.clear();
  emit("image-value", "", "clear");
};

const undo = () => {
  signature.value.undo();
};

const isEmpty = () => {
  return signature.value.isEmpty();
};

defineExpose({
  isEmpty
});
</script>

<style lang="less" scoped>
.signature {
  margin: 0.75rem;
  .canvas {
    border: 0.0625rem dotted #ccc;
  }
  .action {
    margin: 0.75rem 0;
    float: right;
  }
}
</style>

父组件引用

<template>
  <signature ref="canvas" @image-value="getImageValue" />
</template>

<script setup lang="ts">
import { ref, defineAsyncComponent } from "vue";
import { showFailToast } from "vant";

const signature = defineAsyncComponent(
  () => import("@/components/Signature/index.vue")
);

const canvas = ref();

const getImageValue = (value: string, type: string) => {
  if (canvas.value.isEmpty() && type === "save") {
    return showFailToast("请先签名");
  } else {
    console.log(value, "---签名输出的image值---");
  }
};
</script>

实现效果

画布为空时:

画布不为空时:

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3 的组件封装非常简单,下面是一个搜索组件封装示例: 首先,创建一个 Search.vue组件,它的模板如下: ```html <template> <div class="search"> <input type="text" v-model="searchInput" @input="handleInput" /> <button @click="handleSearch">搜索</button> </div> </template> ``` 在组件中,我们需要引入 `reactive`,这是 Vue3 中新加入的函数,用于将数据转换为响应式的数据。我们还需要定义 `props`,用于接收父组件传递的参数,以及定义 `emit`,用于向父组件发送事件。 ```javascript import { defineComponent, reactive, emit } from 'vue'; export default defineComponent({ name: 'Search', props: { placeholder: { type: String, default: '请输入关键词', }, }, setup(props, { emit }) { const searchInput = reactive({ value: '', }); const handleInput = (event) => { searchInput.value = event.target.value; }; const handleSearch = () => { emit('search', searchInput.value); }; return { searchInput, handleInput, handleSearch, }; }, }); ``` 在 `setup` 函数中,我们使用 `reactive` 将 `searchInput` 对象转换为响应式数据。当用户输入关键词时,`handleInput` 函数被调用,将输入的值赋值给 `searchInput.value`。当用户点击搜索按钮时,`handleSearch` 函数被调用,向父组件发送 `search` 事件,并将输入框的值作为参数传递给父组件。 最后,在父组件中使用该组件: ```html <template> <div> <Search placeholder="请输入关键词" @search="handleSearch" /> <ul> <li v-for="item in searchResult" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> import Search from './Search.vue'; export default { components: { Search, }, data() { return { searchResult: [], }; }, methods: { handleSearch(keywords) { // 这里实现搜索逻辑,将搜索结果赋值给 searchResult this.searchResult = [ { id: 1, name: '搜索结果1' }, { id: 2, name: '搜索结果2' }, { id: 3, name: '搜索结果3' }, ]; }, }, }; </script> ``` 在父组件中,我们通过 `@search` 监听子组件的 `search` 事件,并在 `handleSearch` 方法中实现搜索逻辑。将搜索结果赋值给 `searchResult`,然后通过 `v-for` 渲染出结果列表。 这就是 Vue3 中搜索组件封装方法,简单易用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值