From 621fd3a4cbff96dd45cfa9aff3f09d87898d3347 Mon Sep 17 00:00:00 2001 From: "Alex.huxiyang" <1872591453@qq.com> Date: Fri, 19 Jul 2024 13:37:28 +0800 Subject: [PATCH] =?UTF-8?q?fix(cascader):=20=E5=88=9D=E5=A7=8B=E5=8C=96?= =?UTF-8?q?=E8=AE=BE=E7=BD=AEvalue=E6=9C=AA=E6=88=90=E5=8A=9F=E9=80=89?= =?UTF-8?q?=E4=B8=AD=20(#2435)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix(cascader): 初始化设置value未成功选中 * fix(cascader): 初始化设置value未成功选中 * fix(cascader): 初始化设置value未成功选中 * fix(cascader): 初始化设置value未成功选中 --- .../cascader/__tests__/cascader.spec.tsx | 31 ++++++++++++++++--- src/packages/cascader/cascader.taro.tsx | 4 +-- src/packages/cascader/cascader.tsx | 4 +-- src/packages/cascader/demos/h5/demo1.tsx | 12 +++---- src/packages/cascader/demos/h5/demo2.tsx | 14 ++++----- src/packages/cascader/demos/h5/demo5.tsx | 4 +-- src/packages/cascader/demos/taro/demo1.tsx | 12 +++---- src/packages/cascader/demos/taro/demo2.tsx | 14 ++++----- src/packages/cascader/demos/taro/demo5.tsx | 4 +-- 9 files changed, 61 insertions(+), 38 deletions(-) diff --git a/src/packages/cascader/__tests__/cascader.spec.tsx b/src/packages/cascader/__tests__/cascader.spec.tsx index 54a381532b..6299e5eaf8 100644 --- a/src/packages/cascader/__tests__/cascader.spec.tsx +++ b/src/packages/cascader/__tests__/cascader.spec.tsx @@ -321,7 +321,33 @@ describe('Cascader', () => { ).toBe(0) expect(container).toMatchSnapshot() }) - + it('init Value without defaultValue', async () => { + const { container } = render( + + ) + const element = container.querySelectorAll( + '.active.nut-tabpane .active .nut-cascader-item-title' + )[0] + expect(element).toHaveTextContent('鼓楼区') + }) + it('init Value with both valu and defaultValue', async () => { + const { container } = render( + + ) + const element = container.querySelectorAll( + '.active.nut-tabpane .active .nut-cascader-item-title' + )[0] + expect(element).toHaveTextContent('台江区') + }) it('select', async () => { const change = vi.fn() const pathChange = vi.fn() @@ -377,13 +403,10 @@ describe('Cascader', () => { /> ) - expect(container).toMatchSnapshot() - expect(container.querySelector('.nut-popup')).toBe const tabPane = container.querySelectorAll('.nut-tabs-titles-item')[0] fireEvent.click(tabPane) - expect(container).toMatchSnapshot() }) it('ref', async () => { diff --git a/src/packages/cascader/cascader.taro.tsx b/src/packages/cascader/cascader.taro.tsx index 92df6761db..aaecbf8151 100644 --- a/src/packages/cascader/cascader.taro.tsx +++ b/src/packages/cascader/cascader.taro.tsx @@ -211,7 +211,7 @@ const InternalCascader: ForwardRefRenderFunction< if ( currentValue === undefined || - currentValue !== defaultValue || + ![defaultValue, value].includes(currentValue) || !state.tree.nodes.length ) { return @@ -252,7 +252,7 @@ const InternalCascader: ForwardRefRenderFunction< } } - if (needToSync.length && currentValue === defaultValue) { + if (needToSync.length && [defaultValue, value].includes(currentValue)) { const pathNodes = state.tree.getPathNodesByValue(needToSync) pathNodes.forEach((node, index) => { state.tabsCursor = index diff --git a/src/packages/cascader/cascader.tsx b/src/packages/cascader/cascader.tsx index 85dd140377..a9c84f5195 100644 --- a/src/packages/cascader/cascader.tsx +++ b/src/packages/cascader/cascader.tsx @@ -210,7 +210,7 @@ const InternalCascader: ForwardRefRenderFunction< if ( currentValue === undefined || - currentValue !== defaultValue || + ![defaultValue, value].includes(currentValue) || !state.tree.nodes.length ) { return @@ -251,7 +251,7 @@ const InternalCascader: ForwardRefRenderFunction< } } - if (needToSync.length && currentValue === defaultValue) { + if (needToSync.length && [defaultValue, value].includes(currentValue)) { const pathNodes = state.tree.getPathNodesByValue(needToSync) pathNodes.forEach((node, index) => { state.tabsCursor = index diff --git a/src/packages/cascader/demos/h5/demo1.tsx b/src/packages/cascader/demos/h5/demo1.tsx index 57e4d56809..6ad63821de 100644 --- a/src/packages/cascader/demos/h5/demo1.tsx +++ b/src/packages/cascader/demos/h5/demo1.tsx @@ -38,16 +38,16 @@ const Demo1 = () => { text: '长沙', disabled: true, children: [ - { value: '西湖区', text: '西湖区' }, - { value: '余杭区', text: '余杭区' }, + { value: '芙蓉区', text: '芙蓉区' }, + { value: '岳麓区', text: '岳麓区' }, ], }, { - value: '温州', - text: '温州', + value: '岳阳', + text: '岳阳', children: [ - { value: '鹿城区', text: '鹿城区' }, - { value: '瓯海区', text: '瓯海区' }, + { value: '岳阳楼区', text: '岳阳楼区' }, + { value: '云溪区', text: '云溪区' }, ], }, ], diff --git a/src/packages/cascader/demos/h5/demo2.tsx b/src/packages/cascader/demos/h5/demo2.tsx index 8bee8e809c..0b8059a5d8 100644 --- a/src/packages/cascader/demos/h5/demo2.tsx +++ b/src/packages/cascader/demos/h5/demo2.tsx @@ -38,16 +38,16 @@ const Demo2 = () => { text1: '长沙', disabled: true, items: [ - { value1: '西湖区', text1: '西湖区' }, - { value1: '余杭区', text1: '余杭区' }, + { value1: '芙蓉区', text1: '芙蓉区' }, + { value1: '岳麓区', text1: '岳麓区' }, ], }, { - value1: '温州', - text1: '温州', - items: [ - { value1: '鹿城区', text1: '鹿城区' }, - { value1: '瓯海区', text1: '瓯海区' }, + value1: '岳阳', + text1: '岳阳', + children: [ + { value1: '岳阳楼区', text1: '岳阳楼区' }, + { value1: '云溪区', text1: '云溪区' }, ], }, ], diff --git a/src/packages/cascader/demos/h5/demo5.tsx b/src/packages/cascader/demos/h5/demo5.tsx index 53e3112adf..92834f7fc1 100644 --- a/src/packages/cascader/demos/h5/demo5.tsx +++ b/src/packages/cascader/demos/h5/demo5.tsx @@ -6,8 +6,8 @@ const Demo5 = () => { const [value5, setValue5] = useState(['广东省', '广州市']) const [optionsDemo5] = useState([ { value: '北京', text: '北京', id: 1, pidd: null }, - { value: '朝阳区', text: '朝阳区', id: 11, pidd: 1 }, - { value: '亦庄', text: '亦庄', id: 111, pidd: 11 }, + { value: '通州区', text: '通州区', id: 11, pidd: 1 }, + { value: '经海路', text: '经海路', id: 111, pidd: 11 }, { value: '广东省', text: '广东省', id: 2, pidd: null }, { value: '广州市', text: '广州市', id: 21, pidd: 2 }, ]) diff --git a/src/packages/cascader/demos/taro/demo1.tsx b/src/packages/cascader/demos/taro/demo1.tsx index cac7dd58a7..b8dbadeafd 100644 --- a/src/packages/cascader/demos/taro/demo1.tsx +++ b/src/packages/cascader/demos/taro/demo1.tsx @@ -38,16 +38,16 @@ const Demo1 = () => { text: '长沙', disabled: true, children: [ - { value: '西湖区', text: '西湖区' }, - { value: '余杭区', text: '余杭区' }, + { value: '芙蓉区', text: '芙蓉区' }, + { value: '岳麓区', text: '岳麓区' }, ], }, { - value: '温州', - text: '温州', + value: '岳阳', + text: '岳阳', children: [ - { value: '鹿城区', text: '鹿城区' }, - { value: '瓯海区', text: '瓯海区' }, + { value: '岳阳楼区', text: '岳阳楼区' }, + { value: '云溪区', text: '云溪区' }, ], }, ], diff --git a/src/packages/cascader/demos/taro/demo2.tsx b/src/packages/cascader/demos/taro/demo2.tsx index 1dfd4839cd..2ad2a411a1 100644 --- a/src/packages/cascader/demos/taro/demo2.tsx +++ b/src/packages/cascader/demos/taro/demo2.tsx @@ -38,16 +38,16 @@ const Demo2 = () => { text1: '长沙', disabled: true, items: [ - { value1: '西湖区', text1: '西湖区' }, - { value1: '余杭区', text1: '余杭区' }, + { value1: '芙蓉区', text1: '芙蓉区' }, + { value1: '岳麓区', text1: '岳麓区' }, ], }, { - value1: '温州', - text1: '温州', - items: [ - { value1: '鹿城区', text1: '鹿城区' }, - { value1: '瓯海区', text1: '瓯海区' }, + value1: '岳阳', + text1: '岳阳', + children: [ + { value1: '岳阳楼区', text1: '岳阳楼区' }, + { value1: '云溪区', text1: '云溪区' }, ], }, ], diff --git a/src/packages/cascader/demos/taro/demo5.tsx b/src/packages/cascader/demos/taro/demo5.tsx index 0dff010fe8..4df6f2023b 100644 --- a/src/packages/cascader/demos/taro/demo5.tsx +++ b/src/packages/cascader/demos/taro/demo5.tsx @@ -6,8 +6,8 @@ const Demo5 = () => { const [value5, setValue5] = useState(['广东省', '广州市']) const [optionsDemo5] = useState([ { value: '北京', text: '北京', id: 1, pidd: null }, - { value: '朝阳区', text: '朝阳区', id: 11, pidd: 1 }, - { value: '亦庄', text: '亦庄', id: 111, pidd: 11 }, + { value: '通州区', text: '通州区', id: 11, pidd: 1 }, + { value: '经海路', text: '经海路', id: 111, pidd: 11 }, { value: '广东省', text: '广东省', id: 2, pidd: null }, { value: '广州市', text: '广州市', id: 21, pidd: 2 }, ])