output_usage.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. """
  2. 输出演示
  3. ^^^^^^^^^^^
  4. 演示PyWebIO支持的各种输出形式
  5. :demo_host:`Demo地址 </?pywebio_api=output_usage>` `源码 <https://github.com/wang0618/PyWebIO/blob/master/demos/output_usage.py>`_
  6. """
  7. from pywebio import start_server
  8. from pywebio.output import *
  9. from pywebio.session import hold, set_env
  10. def main():
  11. set_env(title="PyWebIO输出演示", auto_scroll_bottom=False)
  12. put_markdown("""# PyWebIO 输入演示
  13. 在[这里](https://github.com/wang0618/PyWebIO/blob/master/demos/input_usage.py)可以获取本Demo的源码。
  14. PyWebIO的输出函数都定义在 `pywebio.output` 模块中,可以使用 `from pywebio.output import *` 引入。
  15. ### 基本输出
  16. PyWebIO提供了一些便捷函数来输出表格、链接等格式:
  17. ```python
  18. # 文本输出
  19. put_text("Hello world!")
  20. # 表格输出
  21. put_table([
  22. ['商品', '价格'],
  23. ['苹果', '5.5'],
  24. ['香蕉', '7'],
  25. ])
  26. # Markdown输出
  27. put_markdown('~~删除线~~')
  28. # 文件输出
  29. put_file('hello_word.txt', b'hello word!')
  30. ```
  31. PyWebIO提供的全部输出函数请参考PyWebIO文档
  32. """, strip_indent=4)
  33. # 文本输出
  34. put_text("Hello world!")
  35. # 表格输出
  36. put_table([
  37. ['商品', '价格'],
  38. ['苹果', '5.5'],
  39. ['香蕉', '7'],
  40. ])
  41. # Markdown输出
  42. put_markdown('~~删除线~~')
  43. # 文件输出
  44. put_file('hello_word.txt', b'hello word!')
  45. put_markdown(r"""### 输出事件回调
  46. PyWebIO允许你输出一些控件,当控件被点击时执行提供的回调函数,就像编写GUI程序一样。
  47. 下面是一个例子:
  48. ```python
  49. from functools import partial
  50. def edit_row(choice, row):
  51. put_markdown("> You click`%s` button ar row `%s`" % (choice, row))
  52. put_table([
  53. ['Idx', 'Actions'],
  54. [1, table_cell_buttons(['edit', 'delete'], onclick=partial(edit_row, row=1))],
  55. [2, table_cell_buttons(['edit', 'delete'], onclick=partial(edit_row, row=2))],
  56. [3, table_cell_buttons(['edit', 'delete'], onclick=partial(edit_row, row=3))],
  57. ])
  58. ```
  59. """, strip_indent=4)
  60. from functools import partial
  61. @use_scope('table-callback')
  62. def edit_row(choice, row):
  63. put_markdown("> You click `%s` button ar row `%s`" % (choice, row))
  64. put_table([
  65. ['Idx', 'Actions'],
  66. [1, table_cell_buttons(['edit', 'delete'], onclick=partial(edit_row, row=1))],
  67. [2, table_cell_buttons(['edit', 'delete'], onclick=partial(edit_row, row=2))],
  68. [3, table_cell_buttons(['edit', 'delete'], onclick=partial(edit_row, row=3))],
  69. ])
  70. set_scope('table-callback')
  71. put_markdown(r"""当然,PyWebIO还支持单独的按钮控件:
  72. ```python
  73. def btn_click(btn_val):
  74. put_markdown("> You click `%s` button" % btn_val)
  75. put_buttons(['A', 'B', 'C'], onclick=btn_click)
  76. ```
  77. """, strip_indent=4)
  78. @use_scope('button-callback')
  79. def btn_click(btn_val):
  80. put_markdown("> You click `%s` button" % btn_val)
  81. put_buttons(['A', 'B', 'C'], onclick=btn_click)
  82. set_scope('button-callback')
  83. put_markdown(r"""### 页面环境设置
  84. #### 输出区外观
  85. PyWebIO支持两种外观:输出区固定高度/可变高度。 可以通过调用 `set_output_fixed_height(True)` 来开启输出区固定高度。
  86. #### 设置页面标题
  87. 调用 `set_title(title)` 可以设置页面标题。
  88. #### 自动滚动
  89. 在不指定锚点进行输出时,PyWebIO默认在输出完毕后自动将页面滚动到页面最下方;在调用输入函数时,也会将页面滚动到表单处。 通过调用 `set_auto_scroll_bottom(False)` 来关闭自动滚动。
  90. """, strip_indent=4)
  91. hold()
  92. if __name__ == '__main__':
  93. start_server(main, debug=True, port=8080)