请详细解释解析<script setup> import { reactive, watch } from "vue"; import SelfEditor from "@/components/SelfEditor/index.vue"; import useJSON from "@/hooks/useJSON"; import { v1 } from "uuid"; import { cloneDeep } from "lodash"; // const props = defineProps({ // 接受数组类型的数据 modelValue: { type: Array, default: () => [], }, }); const emits = defineEmits(["update:modelValue"]); const formRef = ref(); //表单对应的ref // const state = reactive({ dialog: false, //窗口开关 data: [], //段落数据 form: { id: "", title: "", content: "", }, rules: { title: [{ required: true, message: "请输入标题!" }], content: [{ required: true, message: "请输入内容" }], }, // 打开新增 open(data) { state.dialog = true; if (data) { for (let i in state.form) { state.form[i] = data[i]; } } else { state.form.id = v1(); state.form.title = ""; state.form.content = ""; } }, //初始化 initData(data) { state.data = cloneDeep(data) ?? []; }, //新增/编辑 handler(row) { if (row) { } else { state.data.push(cloneDeep(state.form)); } emits("update:modelValue", state.data); state.dialog = false; }, // 清空 clearAll() { state.data = []; }, // 删除 del(data) { state.data = state.data.filter((i) => i.id != data.id); }, }); // watch( () => props.modelValue, (nv) => { state.initData(nv); }, { deep: true, immediate: true } ); </script>
时间: 2024-04-27 11:21:40 浏览: 174
script setup 响应式:核心
这段代码是一个Vue组件的script部分,使用了Vue 3中新增的 `<script setup>` 语法。它导入了一些Vue和第三方库的模块,并定义了一个可响应的对象state,用于管理组件的状态和处理组件的逻辑。
首先,通过 `import` 语句导入了 `reactive`、`watch`、`ref` 等Vue 3中的API、自定义组件 `SelfEditor`、自定义钩子 `useJSON`、第三方库 `uuid` 和 `lodash`。其中 `reactive` 用于创建可响应的对象,`watch` 用于监测数据变化并执行回调函数,`ref` 用于创建一个响应式的引用。 `SelfEditor` 是一个自定义的组件,用于编辑段落的内容。 `useJSON` 是一个自定义的钩子函数,用于处理JSON格式的数据。 `uuid` 用于生成唯一标识符,`lodash` 用于深拷贝对象。
然后,定义了一个 `emits` 对象,它通过 `defineEmits` 函数定义了一个名为 `update:modelValue` 的事件。这个事件用于向父组件发送更新后的 `modelValue` 数据。
接着,定义了一个 `formRef` 对象,用于获取表单的引用。这个引用将在表单提交时使用。
之后,定义了一个可响应的 `state` 对象,它包含了一些属性和方法。
- `dialog`:用于控制弹窗的显示和隐藏。
- `data`:保存段落数据的数组。
- `form`:保存表单数据的对象,包含 `id`、`title` 和 `content` 三个属性。
- `rules`:表单验证规则。
- `open`:用于打开新增或编辑段落的弹窗。
- `initData`:用于初始化段落数据。
- `handler`:用于新增或编辑段落数据。
- `clearAll`:用于清空所有段落数据。
- `del`:用于删除指定的段落数据。
其中, `open` 方法接受一个参数 `data`,用于指定编辑的段落数据。如果传入了 `data`,则将表单数据更新为 `data` 对应的数据;否则,将表单数据初始化为空值。
`initData` 方法接受一个参数 `data`,用于初始化 `state.data` 数组。如果传入了 `data`,则使用 `cloneDeep` 函数将传入的数据深拷贝后,赋值给 `state.data` 数组。如果没有传入参数,则将 `state.data` 数组初始化为空数组。
`handler` 方法用于处理新增或编辑段落数据的逻辑。如果传入了参数 `row`,则表示编辑段落数据。否则,表示新增段落数据。在新增或编辑完成后,通过 `emits` 对象向父组件发送 `update:modelValue` 事件,并传递更新后的 `state.data` 数组。同时,将弹窗关闭。
最后,通过 `watch` 函数监测 `props.modelValue` 数据的变化。当 `props.modelValue` 数据发生变化时,调用 `state.initData` 方法更新 `state.data` 数组。 `deep` 选项表示深度监测,`immediate` 选项表示立即执行一次回调函数。
阅读全文