{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "# `ui.run`\n", "\n", "`ui.run()` 是 NiceGUI 的一个函数,它用于启动用户界面。这个函数可以接受一些可选参数来自定义应用的行为。下面是一些常用的参数:\n", "\n", "- `host`: 指定启动服务器的主机地址。默认值是 `'127.0.0.1'`(在原生模式下),或者 `'0.0.0.0'`(在其他模式下)。\n", "\n", "- `port`: 指定使用哪个端口。默认值是 `8080`(在正常模式下),或者一个自动确定的开放端口(在原生模式下)。\n", "\n", "- `title`: 页面标题。默认值是 `'NiceGUI'`,但是可以在每个页面上重写。\n", "\n", "- `viewport`: 页面元数据视口内容。默认值是 `'width=device-width, initial-scale=1'`,但是可以在每个页面上重写。\n", "\n", "- `favicon`: 相对文件路径,绝对URL到一个 favicon,或者 emoji(例如 `'🚀'`,适用于大多数浏览器)。默认值是 `None`,将使用 NiceGUI 图标。\n", "\n", "- `dark`: 是否使用 Quasar 的暗色模式。默认值是 `False`。如果设置为 `None`,则使用“自动”模式。\n", "\n", "- `language`: Quasar 元素的语言。默认值是 `'en-US'`。\n", "\n", "- `binding_refresh_interval`: 绑定更新之间的时间间隔。默认值是 `0.1` 秒。更大的值对 CPU 更友好。\n", "\n", "- `reconnect_timeout`: 服务器等待浏览器重新连接的最大时间。默认值是 `3.0` 秒。\n", "\n", "- `show`: 是否自动在浏览器标签页中打开用户界面。默认值是 `True`。\n", "\n", "- `on_air`: 技术预览:如果设置为 `True`,允许临时远程访问。默认值是禁用的。\n", "\n", "- `native`: 是否在大小为 800x600 的原生窗口中打开用户界面。默认值是 `False`。如果设置为 `True`,将停用 `show` 选项,并自动找到一个开放的端口。\n", "\n", "- `window_size`: 以提供的尺寸在一个原生窗口中打开用户界面。例如 (1024, 786)。默认值是 `None`,也会激活 `native` 选项。\n", "\n", "- `fullscreen`: 是否在全屏窗口中打开用户界面。默认值是 `False`。如果设置为 `True`,也会激活 `native` 选项。\n", "\n", "- `frameless`: 是否在无边框窗口中打开用户界面。默认值是 `False`。如果设置为 `True`,也会激活 `native` 选项。\n", "\n", "- `reload`: 是否在文件更改时自动重新加载用户界面。默认值是 `True`。\n", "\n", "- `uvicorn_logging_level`: `uvicorn` 服务器的日志记录级别。默认值是 `'warning'`。\n", "\n", "- `uvicorn_reload_dirs`: 以逗号分隔的列表字符串,用于监视的目录。默认值是当前工作目录。\n", "\n", "- `uvicorn_reload_includes`: 以逗号分隔的列表字符串,用于修改时触发重新加载的 `glob` 模式。默认值是 `'*.py'`。\n", "\n", "- `uvicorn_reload_excludes`: 以逗号分隔的列表字符串,应该忽略重新加载的 `glob` 模式。默认值是` '.*, .py[cod], .sw.*, ~*'`。\n", "\n", "- `tailwind`: 是否使用 Tailwind。这是一个实验性的选项,默认值是 `True`。\n", "\n", "- `prod_js`: 是否使用 Vue 和 Quasar 依赖的生产版本。默认值是 `True`。\n", "\n", "- `endpoint_documentation`: 控制哪些端点出现在自动生成的 OpenAPI 文档中。默认值是 `'none'`,选项有 `'none'`, `'internal'`, `'page'`, `'all'`。\n", "\n", "- `storage_secret`: 基于浏览器的存储的秘密密钥。默认值是 `None`,启用 `ui.storage.individual` 和 `ui.storage.browser` 需要一个值。\n", "\n", "- `show_welcome_message`: 是否显示欢迎消息。默认值是 `True`。\n", "\n", "- `kwargs`: 其他关键字参数将传递给 `uvicorn.run`。" ] }, { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "" ] }, "execution_count": 1, "metadata": {}, "output_type": "execute_result" } ], "source": [ "from nicegui import ui\n", "\n", "ui.label('page with custom title')\n", "\n", "# ui.run(title='My App')" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Emoji favicon\n", "\n", "你可以使用表情符号作为网页图标(favicon)。在Chrome、Firefox和Safari浏览器中都可以实现。" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "from nicegui import ui\n", "\n", "ui.label('NiceGUI rocks!')\n", "\n", "# ui.run(favicon='🚀')" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Base64 favicon\n", "\n", "可以使用 base64 编码的图片作为图标。" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [], "source": [ "from nicegui import ui\n", "\n", "ui.label('NiceGUI with a red dot!')\n", "\n", "icon = ''\n", "\n", "# ui.run(favicon=icon)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## SVG favicon\n", "\n", "你可以使用 SVG 作为网页图标(favicon)。在Chrome、Firefox和Safari浏览器中都可以实现。" ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [], "source": [ "from nicegui import ui\n", "\n", "ui.label('NiceGUI makes you smile!')\n", "\n", "smiley = '''\n", " \n", " \n", " \n", " \n", " \n", " \n", "'''\n", "\n", "# ui.run(favicon=smiley)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## 自定义欢迎消息\n", "\n", "你可以通过在命令行中将 `show_welcome_message` 设置为 `False` 来关闭默认的欢迎消息。相反,你可以使用自定义启动处理程序打印自己的欢迎消息。" ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [], "source": [ "from nicegui import app, ui\n", "\n", "ui.label('App with custom welcome message')\n", "\n", "app.on_startup(lambda: print('Visit your app on one of these URLs:', app.urls))\n", "\n", "# ui.run(show_welcome_message=False)" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "py311", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.11.7" } }, "nbformat": 4, "nbformat_minor": 2 }