diff --git a/packages/vant/src/text-ellipsis/README.md b/packages/vant/src/text-ellipsis/README.md
index 15203a36f..07e814e85 100644
--- a/packages/vant/src/text-ellipsis/README.md
+++ b/packages/vant/src/text-ellipsis/README.md
@@ -127,6 +127,28 @@ export default {
};
```
+### Custom Action
+
+Use `action` slots to custom action.
+
+```html
+
+
+ {{ expanded ? 'Collapse' : 'Expand' }}
+
+
+```
+
+```js
+export default {
+ setup() {
+ const text =
+ 'Take your time and be patient. Life itself will eventually answer all those questions it once raised for you.';
+ return { text };
+ },
+};
+```
+
## API
### Props
@@ -154,6 +176,12 @@ Use [ref](https://vuejs.org/guide/essentials/template-refs.html) to get TextElli
| ------ | ---------------------- | -------------------- | ------------ |
| toggle | Toggle expanded status | _expanded?: boolean_ | - |
+### Slots
+
+| Name | Description | SlotProps |
+| --------------- | ------------- | ----------------------- |
+| action `v4.8.3` | Custom action | _{ expanded: boolean }_ |
+
### Types
The component exports the following type definitions:
diff --git a/packages/vant/src/text-ellipsis/README.zh-CN.md b/packages/vant/src/text-ellipsis/README.zh-CN.md
index fd4ed10ba..128ff146a 100644
--- a/packages/vant/src/text-ellipsis/README.zh-CN.md
+++ b/packages/vant/src/text-ellipsis/README.zh-CN.md
@@ -124,6 +124,25 @@ export default {
};
```
+### 自定义操作内容
+
+通过插槽 `action` 自定义操作内容。
+
+```html
+
+ {{ expanded ? '收起' : '展开' }}
+
+```
+
+```js
+export default {
+ setup() {
+ const text = '慢慢来,不要急,生活给你出了难题,可也终有一天会给出答案。';
+ return { text };
+ },
+};
+```
+
## API
### Props
@@ -151,6 +170,12 @@ export default {
| --- | --- | --- | --- |
| toggle | 切换文本的展开状态,传 `true` 为展开,`false` 为收起,不传参为切换 | _expanded?: boolean_ | - |
+### Slots
+
+| 名称 | 说明 | 参数 |
+| --------------- | ---------- | ----------------------- |
+| action `v4.8.3` | 自定义操作 | _{ expanded: boolean }_ |
+
### 类型定义
组件导出以下类型定义:
diff --git a/packages/vant/src/text-ellipsis/TextEllipsis.tsx b/packages/vant/src/text-ellipsis/TextEllipsis.tsx
index a204f48d6..3ebe1be27 100644
--- a/packages/vant/src/text-ellipsis/TextEllipsis.tsx
+++ b/packages/vant/src/text-ellipsis/TextEllipsis.tsx
@@ -37,7 +37,7 @@ export default defineComponent({
emits: ['clickAction'],
- setup(props, { emit }) {
+ setup(props, { emit, slots }) {
const text = ref('');
const expanded = ref(false);
const hasAction = ref(false);
@@ -196,11 +196,16 @@ export default defineComponent({
emit('clickAction', event);
};
- const renderAction = () => (
-
- {actionText.value}
-
- );
+ const renderAction = () => {
+ const action = slots.action
+ ? slots.action({ expanded: expanded.value })
+ : actionText.value;
+ return (
+
+ {action}
+
+ );
+ };
onMounted(calcEllipsised);
diff --git a/packages/vant/src/text-ellipsis/demo/index.vue b/packages/vant/src/text-ellipsis/demo/index.vue
index 12fb62b0b..1eda10b0d 100644
--- a/packages/vant/src/text-ellipsis/demo/index.vue
+++ b/packages/vant/src/text-ellipsis/demo/index.vue
@@ -16,6 +16,7 @@ const t = useTranslate({
collapsePosition: '自定义省略位置',
collapseStart: '头部省略',
collapseMiddle: '中部省略',
+ customAction: '自定义操作内容',
},
'en-US': {
text1:
@@ -31,6 +32,7 @@ const t = useTranslate({
collapsePosition: 'Custom Collapse Position',
collapseStart: 'Head Area Collapse Position',
collapseMiddle: 'Middle Area Collapse Position',
+ customAction: 'Custom Action',
},
});
@@ -77,6 +79,14 @@ const t = useTranslate({
position="middle"
/>
+
+
+
+
+ {{ expanded ? t('collapseText') : t('expandText') }}
+
+
+
diff --git a/packages/vant/src/text-ellipsis/test/__snapshots__/demo-ssr.spec.ts.snap b/packages/vant/src/text-ellipsis/test/__snapshots__/demo-ssr.spec.ts.snap
index c259e8116..bfd7f5f83 100644
--- a/packages/vant/src/text-ellipsis/test/__snapshots__/demo-ssr.spec.ts.snap
+++ b/packages/vant/src/text-ellipsis/test/__snapshots__/demo-ssr.spec.ts.snap
@@ -29,5 +29,10 @@ exports[`should render demo and match snapshot 1`] = `
+
`;
diff --git a/packages/vant/src/text-ellipsis/test/__snapshots__/demo.spec.ts.snap b/packages/vant/src/text-ellipsis/test/__snapshots__/demo.spec.ts.snap
index e6889582a..da3a67515 100644
--- a/packages/vant/src/text-ellipsis/test/__snapshots__/demo.spec.ts.snap
+++ b/packages/vant/src/text-ellipsis/test/__snapshots__/demo.spec.ts.snap
@@ -41,5 +41,13 @@ exports[`should render demo and match snapshot 1`] = `
+
`;
diff --git a/packages/vant/src/text-ellipsis/test/__snapshots__/index.spec.ts.snap b/packages/vant/src/text-ellipsis/test/__snapshots__/index.spec.ts.snap
index bfd0d32d8..efe1a3619 100644
--- a/packages/vant/src/text-ellipsis/test/__snapshots__/index.spec.ts.snap
+++ b/packages/vant/src/text-ellipsis/test/__snapshots__/index.spec.ts.snap
@@ -1,5 +1,32 @@
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
+exports[`should render action slot correctly 1`] = `
+
+ Vant is a lightweight, customizable mobile component library th...
+
+ Collapse
+
+
+`;
+
+exports[`should render action slot correctly 2`] = `
+
+ Vant is a lightweight, customizable mobile component library that was open sourced in 2017. Currently Vant officially provides Vue 2 version, Vue 3 version and WeChat applet version, and the community team maintains React version and Alipay applet version.
+
+ Expand
+
+
+`;
+
+exports[`should render action slot correctly 3`] = `
+
+ Vant is a lightweight, customizable mobile component library th...
+
+ Collapse
+
+
+`;
+
exports[`should render content correctly 1`] = `
Vant is a lightweight, customizable mobile component library th...
diff --git a/packages/vant/src/text-ellipsis/test/index.spec.ts b/packages/vant/src/text-ellipsis/test/index.spec.ts
index 70f4154bc..f5f142079 100644
--- a/packages/vant/src/text-ellipsis/test/index.spec.ts
+++ b/packages/vant/src/text-ellipsis/test/index.spec.ts
@@ -1,6 +1,6 @@
import { mount } from '../../../test';
import { nextTick } from 'vue';
-import TextEllipsis from '..';
+import TextEllipsis, { type TextEllipsisInstance } from '..';
const originGetComputedStyle = window.getComputedStyle;
@@ -32,6 +32,29 @@ afterAll(() => {
window.getComputedStyle = originGetComputedStyle;
});
+test('should render action slot correctly', async () => {
+ const wrapper = mount(TextEllipsis, {
+ props: {
+ content,
+ },
+ slots: {
+ action: ({ expanded }) => (expanded ? 'Expand' : 'Collapse'),
+ },
+ });
+
+ await nextTick();
+
+ expect(wrapper.html()).toMatchSnapshot();
+
+ (wrapper.vm as TextEllipsisInstance).toggle();
+ await nextTick();
+ expect(wrapper.html()).toMatchSnapshot();
+
+ (wrapper.vm as TextEllipsisInstance).toggle();
+ await nextTick();
+ expect(wrapper.html()).toMatchSnapshot();
+});
+
test('should render content correctly', async () => {
const wrapper = mount(TextEllipsis, {
props: {