UI Views - List列表 - 《Ant Design Mobile v0.8.x 组件文档》 (2024)

  • List 列表
    • 规则
  • 代码演示
  • API
    • List
    • List.Item
    • List.Item.Brief
    单个连续模块垂直排列,显示当前的内容、状态和可进行的操作。eg:联系人列表。

    规则

    代码演示

    列表项类表单组件大集合(rc-form的基础用法请查看源码)

    表单集合. (rc-form 文档,更多用法请详细阅读此文档)
    1. import { List, InputItem, Switch, Stepper, Slider, Radio, TextareaItem, WingBlank, WhiteSpace, Button } from 'antd-mobile';
    2. import { createForm } from 'rc-form';
    3. let BasicInput = React.createClass({
    4. getInitialState() {
    5. return {
    6. disabled: false,
    7. value: 1,
    8. };
    9. },
    10. handleChange(e) {
    11. if (e.target.checked) {
    12. this.setState({
    13. value: 1,
    14. });
    15. }
    16. },
    17. handleChange2(e) {
    18. if (e.target.checked) {
    19. this.setState({
    20. value: 2,
    21. });
    22. }
    23. },
    24. onSubmit() {
    25. this.props.form.validateFields({ force: true }, (error, values) => {
    26. if (!error) {
    27. const formValue = this.props.form.getFieldsValue();
    28. console.log(values);
    29. console.log(formValue);
    30. } else {
    31. alert('校验失败');
    32. }
    33. });
    34. },
    35. onReset() {
    36. this.props.form.resetFields();
    37. alert('重制完成');
    38. },
    39. validateAccount(rule, value, callback) {
    40. if (value && value.length > 4) {
    41. callback();
    42. } else {
    43. callback(new Error('帐号至少4个字符'));
    44. }
    45. },
    46. render() {
    47. const { getFieldProps, getFieldError } = this.props.form;
    48. return (<div>
    49. <List
    50. title="表单输入项"
    51. footer={getFieldError('account') && getFieldError('account').join(',')}
    52. >
    53. <InputItem
    54. {...getFieldProps('account', {
    55. initialValue: '小蚂蚁',
    56. rules: [
    57. { required: true, message: '请输入帐号' },
    58. { validator: this.validateAccount },
    59. ],
    60. })}
    61. clear
    62. error={!!getFieldError('account')}
    63. onErrorClick={() => {
    64. alert(getFieldError('account').join('、'));
    65. }}
    66. >帐号</InputItem>
    67. <InputItem
    68. {...getFieldProps('password')}
    69. clear
    70. placeholder="请输入密码"
    71. type="password"
    72. >密码</InputItem>
    73. <InputItem
    74. {...getFieldProps('input1', {
    75. initialValue: '1245',
    76. })}
    77. clear
    78. error
    79. placeholder="校验样式"
    80. type="password"
    81. >密码</InputItem>
    82. </List>
    83. <List
    84. title="表单展示项"
    85. >
    86. <List.Item
    87. thumb="https://zos.alipayobjects.com/rmsportal/dNuvNrtqUztHCwM.png"
    88. arrow="horizontal"
    89. >我的钱包</List.Item>
    90. <List.Item
    91. thumb="https://zos.alipayobjects.com/rmsportal/UmbJMbWOejVOpxe.png"
    92. arrow="horizontal"
    93. >我的花销占比</List.Item>
    94. </List>
    95. <List
    96. title="表单控件"
    97. >
    98. <List.Item
    99. extra={<Switch
    100. {...getFieldProps('1', {
    101. initialValue: true,
    102. valuePropName: 'checked',
    103. })}
    104. />}
    105. >使用 Ant Desgin Component</List.Item>
    106. <List.Item>
    107. <Slider range defaultValue={[20, 50]} />
    108. </List.Item>
    109. <List.Item
    110. extra={<Stepper showNumber size="small" max={10} min={1} defaultValue={20} onChange={() => {}} />}
    111. >预定人数</List.Item>
    112. </List>
    113. <List>
    114. <TextareaItem
    115. {...getFieldProps('note7', {
    116. initialValue: '如果你有什么建议意见,欢迎你来吐槽',
    117. })}
    118. labelNumber={4}
    119. name="yyy"
    120. rows={5}
    121. placeholder="计数功能"
    122. clear
    123. count={100}
    124. onBlur={() => { console.log('onBlur'); }}
    125. onFocus={(e) => { console.log('onFocus'); console.log(e); }}
    126. />
    127. </List>
    128. <List
    129. title="列表单选"
    130. >
    131. <Radio.RadioItem
    132. checked={this.state.value === 1}
    133. onChange={this.handleChange}
    134. disabled={this.state.disabled}
    135. >
    136. 选项一
    137. </Radio.RadioItem>
    138. <Radio.RadioItem
    139. checked={this.state.value === 2}
    140. onChange={this.handleChange2}
    141. disabled={this.state.disabled}
    142. >
    143. 选项二
    144. </Radio.RadioItem>
    145. <Radio.RadioItem
    146. checked
    147. onChange={this.handleChange}
    148. disabled
    149. >
    150. 选项三
    151. </Radio.RadioItem>
    152. <Radio.RadioItem
    153. checked={false}
    154. onChange={this.handleChange}
    155. disabled
    156. >
    157. 选项四
    158. </Radio.RadioItem>
    159. </List>
    160. <WhiteSpace />
    161. <WingBlank size="lg">
    162. <Button type="primary" onClick={this.onSubmit}>提交验证</Button>
    163. <WhiteSpace />
    164. <Button onClick={this.onReset}>重置</Button>
    165. </WingBlank>
    166. <WhiteSpace />
    167. <WhiteSpace />
    168. </div>);
    169. },
    170. });
    171. BasicInput = createForm()(BasicInput);
    172. ReactDOM.render(<BasicInput />, mountNode);

    基本

    基本用法. (rc-form 文档)
    1. import { List } from 'antd-mobile';
    2. import { createForm } from 'rc-form';
    3. let ListExample = React.createClass({
    4. render() {
    5. return (<form>
    6. <List
    7. title="我是华丽丽的列表头部"
    8. footer="我是列表尾部"
    9. >
    10. <List.Item>没有设置onClick则点击无反馈,文字超长则隐藏</List.Item>
    11. <List.Item wrap>文字超长折行文字超长折行文字超长折行文字超长折行文字超长折行文字超长折行</List.Item>
    12. <List.Item
    13. onClick={() => {}}
    14. extra={undefined}
    15. >标题文字</List.Item>
    16. <List.Item
    17. extra="内容内容"
    18. onClick={() => {}}
    19. arrow="horizontal"
    20. >标题文字</List.Item>
    21. </List>
    22. <List
    23. title="下拉框"
    24. >
    25. <List.Item
    26. extra={<select style={{ direction: 'rtl' }} defaultValue="2">
    27. <option value="1">选项1</option>
    28. <option value="2">选项2</option>
    29. <option value="3" disabled>选项3不可选</option>
    30. </select>}
    31. arrow="horizontal"
    32. >下拉框</List.Item>
    33. <List.Item
    34. arrow="horizontal"
    35. >
    36. <select defaultValue="3">
    37. <option value="1">选项1</option>
    38. <option value="2" disabled>选项2不可选</option>
    39. <option value="3">选项3</option>
    40. </select>
    41. </List.Item>
    42. </List>
    43. <List
    44. title="带缩略图"
    45. >
    46. <List.Item
    47. thumb="https://zos.alipayobjects.com/rmsportal/zotStpFiYpNtZNl.png"
    48. arrow="horizontal"
    49. onClick={() => {}}
    50. >thumb</List.Item>
    51. <List.Item
    52. thumb="https://zos.alipayobjects.com/rmsportal/zotStpFiYpNtZNl.png"
    53. >thumb</List.Item>
    54. <List.Item
    55. icon=""
    56. extra={<img src="https://zos.alipayobjects.com/rmsportal/zotStpFiYpNtZNl.png" width="28" height="28" />}
    57. arrow="horizontal"
    58. >extraimg标签</List.Item>
    59. </List>
    60. </form>);
    61. },
    62. });
    63. ListExample = createForm()(ListExample);
    64. ReactDOM.render(<ListExample />, mountNode);
    1. /** hack for antd responsive conflict */
    2. @media only screen and (max-width: 767px) and (min-width: 320px) {
    3. #list {
    4. display: block;
    5. }
    6. }

    是否带箭头/箭头方向

    单行列表
    1. import { List } from 'antd-mobile';
    2. window.clickItem = (e) => {
    3. console.log(e);
    4. console.log(this);
    5. console.log(ReactDOM.findDOMNode(this));
    6. console.log($(ReactDOM.findDOMNode(this)).find('.am-list-extra'));
    7. $(ReactDOM.findDOMNode(this)).find('.am-list-extra').css('color', 'red');
    8. };
    9. window.openurl = (e) => {
    10. e.preventDefault();
    11. let target = e.target;
    12. if (!$(target).hasClass('am-list-item')) {
    13. target = $(target).parents('.am-list-item')[0];
    14. }
    15. window.location.href = target.href;
    16. };
    17. ReactDOM.render(
    18. <div>
    19. <List
    20. title="箭头方向"
    21. >
    22. <List.Item extra="horizontal,箭头向右" arrow="horizontal" onClick={() => {}}>标题文字</List.Item>
    23. <List.Item extra="down,箭头向下" arrow="down" onClick={() => {}}>标题文字</List.Item>
    24. <List.Item extra="up,箭头向上" arrow="up" onClick={() => {}}>标题文字</List.Item>
    25. <List.Item
    26. extra={<div>内容内容<List.Item.Brief>辅助文字内容</List.Item.Brief></div>}
    27. arrow="horizontal"
    28. onClick={() => {}}
    29. multipleLine
    30. >标题文字<List.Item.Brief>辅助文字内容</List.Item.Brief></List.Item>
    31. <List.Item
    32. extra={<div>内容内容<List.Item.Brief>辅助文字内容</List.Item.Brief></div>}
    33. arrow="down"
    34. onClick={() => {}}
    35. multipleLine
    36. >标题文字<List.Item.Brief>辅助文字内容</List.Item.Brief></List.Item>
    37. <List.Item
    38. extra={<div>内容内容<List.Item.Brief>辅助文字内容</List.Item.Brief></div>}
    39. arrow="up"
    40. error
    41. onClick={() => {}}
    42. multipleLine
    43. >标题文字<List.Item.Brief>辅助文字内容</List.Item.Brief></List.Item>
    44. <List.Item
    45. extra="empty,有箭头坑位"
    46. arrow="empty"
    47. onClick={() => {}}
    48. multipleLine
    49. >内容内容</List.Item>
    50. <List.Item
    51. extra="校验报错"
    52. error
    53. onClick={() => {}}
    54. >内容内容</List.Item>
    55. </List>
    56. </div>
    57. , mountNode);

    对齐方式

    双行列表
    1. import { List, Button } from 'antd-mobile';
    2. const Brief = List.Item.Brief;
    3. ReactDOM.render(
    4. <div>
    5. <List title="对齐">
    6. <List.Item
    7. extra={<div>内容内容<Brief>辅助文字内容</Brief><Brief>辅助文字内容</Brief></div>}
    8. arrow="horizontal"
    9. onClick={() => {}}
    10. multipleLine
    11. >垂直居中对齐</List.Item>
    12. <List.Item
    13. extra="内容内容"
    14. arrow="horizontal"
    15. onClick={() => {}}
    16. multipleLine
    17. ><div>垂直居中对齐<Brief>辅助文字内容</Brief><Brief>辅助文字内容</Brief></div></List.Item>
    18. <List.Item
    19. extra={<div>内容内容<Brief>辅助文字内容</Brief><Brief>辅助文字内容</Brief></div>}
    20. arrow="horizontal"
    21. align="top"
    22. onClick={() => {}}
    23. multipleLine
    24. >顶部对齐</List.Item>
    25. <List.Item
    26. extra="内容内容"
    27. arrow="horizontal"
    28. align="top"
    29. onClick={() => {}}
    30. multipleLine
    31. ><div>顶部对齐<Brief>辅助文字内容</Brief></div></List.Item>
    32. <List.Item
    33. extra={<div>内容内容<Brief>辅助文字内容</Brief></div>}
    34. arrow="horizontal"
    35. align="bottom"
    36. onClick={() => {}}
    37. multipleLine
    38. >底部对齐</List.Item>
    39. <List.Item
    40. extra="内容内容"
    41. arrow="horizontal"
    42. align="bottom"
    43. onClick={() => {}}
    44. multipleLine
    45. ><div>底部对齐<Brief>辅助文字内容</Brief></div></List.Item>
    46. <List.Item
    47. extra={<Button
    48. size="small"
    49. inline
    50. onClick={() => alert(111)}
    51. >按钮</Button>}
    52. multipleLine
    53. ><div><div>区域经理</div><Brief>可进行收款、退款、折扣管理、查看数据等操作</Brief></div></List.Item>
    54. </List>
    55. </div>
    56. , mountNode);

    业务示例

    一个业务上使用的示例。
    1. import { List } from 'antd-mobile';
    2. ReactDOM.render(
    3. <div>
    4. <List>
    5. <List.Item
    6. extra="鹿港小镇"
    7. arrow="horizontal"
    8. onClick={() => {}}
    9. >所属门店</List.Item>
    10. <List.Item
    11. extra="张三"
    12. arrow="empty"
    13. onClick={() => {}}
    14. >员工姓名</List.Item>
    15. <List.Item
    16. extra="收银员"
    17. arrow="empty"
    18. onClick={() => {}}
    19. >员工角色</List.Item>
    20. <List.Item
    21. extra="13838383756"
    22. arrow="empty"
    23. onClick={() => {}}
    24. >员工手机</List.Item>
    25. <List.Item
    26. extra="只可退自己的"
    27. arrow="empty"
    28. onClick={() => {}}
    29. >退款权限</List.Item>
    30. <List.Item
    31. extra="其他权限"
    32. arrow="horizontal"
    33. onClick={() => {}}
    34. >文本信息</List.Item>
    35. <List.Item
    36. extra={<img src="" />}
    37. arrow="horizontal"
    38. onClick={() => {}}
    39. >员工二维码</List.Item>
    40. <List.Item
    41. extra={<div>zhifubao@alipay.com#<List.Item.Brief>001</List.Item.Brief></div>}
    42. arrow="horizontal"
    43. onClick={() => {}}
    44. multipleLine
    45. >垂直居中对齐</List.Item>
    46. <List.Item
    47. extra={<div>zhifubao@alipay.com#<List.Item.Brief>001</List.Item.Brief></div>}
    48. arrow="horizontal"
    49. align="top"
    50. onClick={() => {}}
    51. multipleLine
    52. >顶部对齐</List.Item>
    53. <List.Item
    54. extra={<div>zhifubao@alipay.com#<List.Item.Brief>001</List.Item.Brief></div>}
    55. arrow="horizontal"
    56. align="bottom"
    57. onClick={() => {}}
    58. multipleLine
    59. >底部对齐</List.Item>
    60. <List.Item
    61. extra={<div>zhifubao@alipay.com#<List.Item.Brief>001</List.Item.Brief></div>}
    62. arrow="horizontal"
    63. align="top"
    64. onClick={() => {}}
    65. multipleLine
    66. wrap
    67. >文字超长折行文字超长折行</List.Item>
    68. </List>
    69. </div>
    70. , mountNode);

    UI Views - List列表 - 《Ant Design Mobile v0.8.x 组件文档》 (1)

    API

    List

    成员说明类型默认值
    titlelist titleReactNode
    footerlist footerReactNode

    List.Item

    成员说明类型可选值默认值
    thumb缩略图imgsrc
    extra右边内容String/HTML
    arrow箭头方向(右,上,下),如果是empty,则存在对应的dom,但是不显示Stringhorizontalupdownempty、无
    alignFlex 子元素垂直对齐Stringtopmiddlebottommiddle
    onClick点击事件的回调函数Function
    error报错样式,右侧文字颜色变成橙色Booleantruefalsefalse
    multipleLine多行Booleantruefalsefalse
    wrap是否换行,默认情况下,文字超长会被隐藏,Booleantruefalsefalse

    List.Item.Brief

    辅助说明
    UI Views - List列表 - 《Ant Design Mobile v0.8.x 组件文档》 (2024)

    References

    Top Articles
    Latest Posts
    Article information

    Author: Rev. Porsche Oberbrunner

    Last Updated:

    Views: 5596

    Rating: 4.2 / 5 (73 voted)

    Reviews: 80% of readers found this page helpful

    Author information

    Name: Rev. Porsche Oberbrunner

    Birthday: 1994-06-25

    Address: Suite 153 582 Lubowitz Walks, Port Alfredoborough, IN 72879-2838

    Phone: +128413562823324

    Job: IT Strategist

    Hobby: Video gaming, Basketball, Web surfing, Book restoration, Jogging, Shooting, Fishing

    Introduction: My name is Rev. Porsche Oberbrunner, I am a zany, graceful, talented, witty, determined, shiny, enchanting person who loves writing and wants to share my knowledge and understanding with you.