From 5f2f7d49f11ddf6074f657888c9261db21e14ffc Mon Sep 17 00:00:00 2001 From: Barrior Date: Sat, 6 Jul 2024 10:12:51 +0800 Subject: [PATCH] =?UTF-8?q?docs:=20=E4=BC=98=E5=8C=96=E6=96=87=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../880-relation-checkbox.md | 4 +- .../881-relation-select-multiple.md | 52 ++++++++++--------- 2 files changed, 30 insertions(+), 26 deletions(-) diff --git a/examples/form-render-react/880-relation-checkbox.md b/examples/form-render-react/880-relation-checkbox.md index 80ab58b..d9bd3e2 100644 --- a/examples/form-render-react/880-relation-checkbox.md +++ b/examples/form-render-react/880-relation-checkbox.md @@ -88,7 +88,7 @@ const Demo = () => { // 将可选城市范围数据赋值给 userCtx userCtx.current.cityList = event.extra.checkedOptions - // 已选中的值不在范围内,则清楚 + // 已选中的值不在范围内,则清除 if (!event.value.includes(formData.available_cities)) { formData.available_cities = undefined } @@ -154,7 +154,7 @@ const Demo = () => { schema.properties.available_cities.renderOptions.options = event.extra.checkedOptions - // 已选中的值不在范围内,则清楚 + // 已选中的值不在范围内,则清除 if (!event.value.includes(formData.available_cities)) { formData.available_cities = undefined } diff --git a/examples/form-render-react/881-relation-select-multiple.md b/examples/form-render-react/881-relation-select-multiple.md index e10abfe..16c99e3 100644 --- a/examples/form-render-react/881-relation-select-multiple.md +++ b/examples/form-render-react/881-relation-select-multiple.md @@ -18,31 +18,37 @@ import { useState } from 'react' import SyntaxHighlighter from '@examples/components/SyntaxHighlighter' import FormRender from '@schema-render/form-render-react' -const schema = { - renderType: 'Root', - properties: { - cities: { - title: '设置可选城市范围', - renderType: 'SelectMultiple', - renderOptions: { - options: [ - { label: '成都', value: 'chengdu' }, - { label: '杭州', value: 'hangzhou' }, - { label: '深圳', value: 'shenzhen' }, - { label: '北京', value: 'beijing' }, - ], +function createSchema(available_cities_options = []) { + const schema = { + renderType: 'Root', + properties: { + cities: { + title: '设置可选城市范围', + renderType: 'SelectMultiple', + renderOptions: { + options: [ + { label: '成都', value: 'chengdu' }, + { label: '杭州', value: 'hangzhou' }, + { label: '深圳', value: 'shenzhen' }, + { label: '北京', value: 'beijing' }, + ], + }, + }, + available_cities: { + title: '设置可选城市', + renderType: 'Checkbox', + renderOptions: { + options: available_cities_options, + }, }, }, - available_cities: { - title: '设置可选城市', - renderType: 'Checkbox', - renderOptions: {}, - }, - }, + } + return schema } const Demo = () => { const [value, setValue] = useState({}) + const [schema, setSchema] = useState(() => createSchema()) return (
@@ -54,12 +60,10 @@ const Demo = () => { onChange={setValue} watch={{ cities: (formData, event) => { - console.log(event) - // 修改 schema 参数,重新渲染的时候会被应用 - schema.properties.available_cities.renderOptions.options = - event.extra.selectedOptions + // 基于下拉选中项,重新创建 schema 渲染 + setSchema(createSchema(event.extra.selectedOptions)) - // 已选中的值不在范围内,则清楚 + // 已选中的值不在范围内,则清除 if (!event.value.includes(formData.available_cities)) { formData.available_cities = undefined }