@yookue/react-condition v0.1.22
@yookue/react-condition
🏅 React 條件性渲染組件 👍
特性
✅ 支持 'If' 條件渲染
✅ 支持 'If'-'Then' 條件渲染
✅ 支持 'If'-'Else' 條件渲染
✅ 支持 'If'-'Then'-Else' 條件渲染
✅ 支持 'For' 條件渲染
✅ 支持 'Do' 條件渲染
✅ 支持 'While' 條件渲染
✅ 支持 'MapIterator' 條件渲染
✅ 支持 'SetIterator' 條件渲染
✅ 支持 'ObjectIterator' 條件渲染
快速開始
您可以在您的 React 項目中使用以下命令來安裝本組件庫:
$ npm install @yookue/react-condition --save
然后,您可以使用以下命令來導入組件:
import {If, For, Switch, Do, While} from '@yookue/react-condition';
import {MapIterator, SetIterator, ObjectIterator} from '@yookue/react-condition';
享受您和 react-condition
的編程之旅吧 ✌️
示例
If
If.Then
和If.Else
都有一個render
屬性() => React.ReactNode
,這樣您也可以通過它來返回自定義的渲染內容, 比 React 的children
屬性權重要高。
If
語句
import React from 'react';
import {If} from '@yookue/react-condition';
export default () => {
const param = true;
return (
<If condition={param}>
<span>Hello World</span>
</If>
);
}
If
-Then
語句
import React from 'react';
import {If} from '@yookue/react-condition';
export default () => {
const param = 1;
return (
<If condition={param}>
<If.Then>
<span>Hello World</span>
</If.Then>
</If>
);
}
If
-Else
語句
import React from 'react';
import {If} from '@yookue/react-condition';
export default () => {
const param = false;
return (
<If condition={param}>
<span>Hello World</span>
<If.Else>
<span>Hello Yookue</span>
</If.Else>
</If>
);
}
If
-Then
-Else
語句
import React from 'react';
import {If} from '@yookue/react-condition';
export default () => {
const param = false;
return (
<If condition={param}>
<If.Then>
<span>Hello World</span>
</If.Then>
<If.Else>
<span>Hello Yookue</span>
</If.Else>
</If>
);
}
For
語句
import React from 'react';
import {For} from '@yookue/react-condition';
export default () => {
return (
<For
of={['foo', 'bar']}
render={(item, index) => {
return (
<span key={index}>Hello, {item}</span>
);
}}
/>
);
}
Switch
語句
Switch.Case
和Switch.Default
都有一個render
屬性() => React.ReactNode
,這樣您也可以通過它來返回自定義的渲染內容, 比 React 的children
屬性權重要高。
import React from 'react';
import {Switch} from '@yookue/react-condition';
export default () => {
const username = 'admin';
return (
<Switch>
<Switch.Case condition={username.includes('admin')}>
<span>admin</span>
</Switch.Case>
<Switch.Case condition={username.includes('guest')}>
<span>guest</span>
</Switch.Case>
<Switch.Default>
<span>root</span>
</Switch.Default>
</Switch>
);
}
Do
語句
import React from 'react';
import {Do} from '@yookue/react-condition';
export default () => {
let param = 0;
return (
<Do
condition={() => {
return param < 2;
}}
render={(index) => {
param++;
return (
<span key={index}>Hello, {index}</span>
);
}}
/>
);
}
While
語句
import React from 'react';
import {While} from '@yookue/react-condition';
export default () => {
let param = 0;
return (
<While
condition={() => {
return param++ < 2;
}}
render={(index) => {
return (
<span key={index}>Hello, {index}</span>
);
}}
/>
);
}
MapIterator
語句
import React from 'react';
import {MapIterator} from '@yookue/react-condition';
export default () => {
const map = new Map([
['foo', 'bar'],
['hello', 'world'],
]);
return (
<MapIterator
of={map}
render={(value, key, index) => {
return (
<span key={index}>Hooray, {key}-{value}</span>
);
}}
/>
);
}
SetIterator
語句
import React from 'react';
import {SetIterator} from '@yookue/react-condition';
export default () => {
const set = new Set<string>([
'foo-bar',
'hello-world',
]);
return (
<SetIterator
of={set}
render={(item, index) => {
return (
<span key={index}>Hooray, {item}</span>
);
}}
/>
);
}
ObjectIterator
語句
import React from 'react';
import {ObjectIterator} from '@yookue/react-condition';
export default () => {
const param = {
'foo': 'bar',
'hello': 'world',
};
return (
<ObjectIterator
of={param}
render={(value, key, index) => {
return (
<span key={index}>Hooray, {key}-{value}</span>
);
}}
/>
);
}
授權
本組件庫授權基于 MIT License 協議
版權
北京攸科網絡科技有限公司
網站
- Yookue: https://yookue.com
4 months ago
6 months ago
6 months ago
8 months ago
8 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago