熟悉Quasar项目中可用的命令列表:
$ quasar
___
/ _ \ _ _ __ _ ___ __ _ _ __
| | | | | | |/ _` / __|/ _` | '__|
| |_| | |_| | (_| \__ \ (_| | |
\__\_\\__,_|\__,_|___/\__,_|_|
Example usage
$ quasar <command> <options>
Help for a command
$ quasar <command> --help
$ quasar <command> -h
Options
--version, -v Print Quasar App CLI version
Commands
dev, d Start a dev server for your App
build, b Build your app for production
clean, c Clean all build artifacts
new, n Quickly scaffold page/layout/component/... vue file
mode, m Add/remove Quasar Modes for your App
inspect Inspect generated Webpack config
ext, e Manage Quasar App Extensions
run, r Run specific command provided by an installed
Quasar App Extension
describe Describe a Quasar API (component)
test, t Run @quasar/testing App Extension command
- requires @quasar/testing App Extension to be installed
- this is an alias command for convenience purposes
info, i Display info about your machine and your App
help, h Displays this message
If the specified command is not found, then "quasar run"
will be executed with the provided arguments.
Commands supplied by @quasar/cli global installation:
upgrade Check (and optionally) upgrade Quasar packages
from a Quasar project folder
serve Create an ad-hoc server on App's distributables
查看任一命令的帮助信息:
$ quasar [command name] --help
创建
使用自定义的入门套件创建应用文件夹。
你可能要找yarn create quasar
或npm init quasar
来代替。
$ quasar create <folder_name> --kit <address> [--branch <branch_name>]
您可以通过提供一个文件夹本地路径来使用存储在您机器上的初学者工具包(例如quasar create --kit ./my-custom-starter-kit
)。
通过提供遵循以下架构的引用,可以使用存储在任何可公开访问的Git存储库中的初学者工具包:
- GitHub -
github:owner/name
或者只是owner/name
- GitLab -
gitlab:owner/name
- Bitbucket -
bitbucket:owner/name
默认情况下,master
分支将被签出,但您可以通过--branch <branch name>
(例如quasar create --kit owner/name --branch my-branch
)指定您喜欢的分支。
WARNING
在Quasar生态系统中构建可重用代码和UI组件的首选方法是应用扩展。只有当你真的知道自己在做什么,并且意识到这将使Quasar团队更难为你提供帮助时,才使用定制的入门套件。
升级@quasar/cli v1.1+ specs
从Quasar项目文件夹检查(可选的)升级Quasar包:
# view all options:
$ quasar upgrade -h
# checks for non-breaking change upgrades and displays them,
# but will not carry out the install
$ quasar upgrade
# checks for pre-releases (alpha/beta):
$ quasar upgrade -p
# checks for major new releases (includes breaking changes):
$ quasar upgrade -m
# to perform the actual upgrade,
# combine any of the params above and add "-i" (or "--install"):
$ quasar upgrade -i
代码编辑器终端注意事项
如果您使用的是代码编辑器终端而不是真正的终端,运行quasar upgrade
并收到错误Command not found或*@quasar/cli版本显示是undefined*,您需要去代码编辑器终端的设置取消*将项目根目录中的’node_modules/.bin’添加到%PATH%*选项(或其等效项)然后重新启动代码编辑器。
信息
Quasar CLI配备了多个NPM构建包(Webpack,Vue等)的稳定组合,经过严格测试后会经常更新。
为了让您看到Node,NPM,Quasar CLI,Quasar,Vue,Webpack,Cordova,Babel等多个版本,请在Quasar项目文件夹中发出以下命令:
$ quasar info
开发
$ quasar dev -h
Description
Starts the app in development mode (hot-code reloading, error
reporting, etc)
Usage
$ quasar dev
$ quasar dev -p <port number>
$ quasar dev -m ssr
# alias for "quasar dev -m cordova -T ios"
$ quasar dev -m ios
# alias for "quasar dev -m cordova -T android"
$ quasar dev -m android
# passing extra parameters and/or options to
# underlying "cordova" or "electron" executables:
$ quasar dev -m ios -- some params --and options --here
$ quasar dev -m electron -- --no-sandbox --disable-setuid-sandbox
Options
--mode, -m App mode [spa|ssr|pwa|bex|cordova|capacitor|electron] (default: spa)
--port, -p A port number on which to start the application
--hostname, -H A hostname to use for serving the application
--help, -h Displays this message
Only for Cordova mode:
--target, -T (required) App target
[android|ios]
--emulator, -e (optional) Emulator name
Examples: iPhone-7, iPhone-X
iPhone-X,com.apple.CoreSimulator.SimRuntime.iOS-12-2
--ide, -i Open IDE (Android Studio / XCode) instead of letting Cordova
booting up the emulator, in which case the "--emulator"
param will have no effect
--devtools, -d Open remote Vue Devtools
Only for Capacitor mode:
--target, -T (required) App target
[android|ios]
Quasar开发服务器允许您通过编译和维护内存代码来开发您的应用程序。 一个Web服务器将为您的应用程序提供开箱即用的热重载功能。 在内存运行可以在更改代码时提供更快的重建速度。
热重载不仅仅是在代码更改时刷新浏览器。 它会跳过刷新并在运行中更新您的代码,同时保持您的应用程序的状态(如您的Vue的模型数据)。 请注意,有些情况下这是不可能的,所以开发服务器将会简单刷新你的浏览器。 (一定要确保一次只运行一个Quasar CLI实例,否则热重载和其他功能将会中断!)
根据您要开发的内容,您可以使用“quasar dev”命令启动开发服务器,如下所示:
# Developing a SPA
$ quasar dev
# ...or
$ quasar dev -m spa
# Developing for SSR
$ quasar dev -m ssr
# Developing a PWA
$ quasar dev -m pwa
# Developing a BEX for production
$ quasar dev -m bex
# Developing a Mobile App (through Cordova)
$ quasar dev -m cordova -T [android|ios]
# or the short form:
$ quasar dev -m [android|ios]
# Developing an Electron App
$ quasar dev -m electron
# passing extra parameters and/or options to
# underlying "cordova" or "electron" executables:
$ quasar dev -m ios -- some params --and options --here
$ quasar dev -m electron -- --no-sandbox --disable-setuid-sandbox
如果您想更改为您的应用程序提供服务的主机名或端口,您有3个选项:
- 编辑’/quasar.conf.js’:
devServer: { host: '...', port: ... }
- 通过’-H’(主机名)和’-p’(端口)命令选项。
- 如果这是一次性事情,请将主机名和/或端口指定为环境变量:
$ PORT=3000 quasar dev $ HOSTNAME=1.1.1.14 quasar dev
如果热重载似乎存在问题,您可以尝试两个修补程序:
更改项目文件夹的权限
sudo chown -R username: .
或者以root权限运行开发服务器
sudo quasar dev
构建
$ quasar build -h
Description
Builds distributables of your app.
Usage
$ quasar build
$ quasar build -p <port number>
$ quasar build -m ssr
# alias for "quasar build -m cordova -T ios"
$ quasar build -m ios
# alias for "quasar build -m cordova -T android"
$ quasar build -m android
# passing extra parameters and/or options to
# underlying "cordova" executable:
$ quasar build -m ios -- some params --and options --here
Options
--mode, -m App mode [spa|ssr|pwa|bex|cordova|capacitor|electron] (default: spa)
--target, -T App target
- Cordova (default: all installed)
[android|ios]
- Capacitor
[android|ios]
- Electron with default "electron-packager" bundler (default: yours)
[darwin|win32|linux|mas|all]
- Electron with "electron-builder" bundler (default: yours)
[darwin|mac|win32|win|linux|all]
--publish, -P Also trigger publishing hooks (if any are specified)
- Has special meaning when building with Electron mode and using
electron-builder as bundler
--debug, -d Build for debugging purposes
--skip-pkg, -s Build only UI (skips creating Cordova/Electron executables)
- Cordova (it only fills in /src/cordova/www folder with the UI code)
- Capacitor (it only fills in /src/capacitor/www folder with the UI code)
- Electron (it only creates the /dist/electron/UnPackaged folder)
--help, -h Displays this message
ONLY for Cordova and Capacitor mode:
--ide, -i Open IDE (Android Studio / XCode) instead of finalizing with a
terminal/console-only build
ONLY for Electron mode:
--bundler, -b Bundler (electron-packager or electron-builder)
[packager|builder]
--arch, -A App architecture (default: yours)
- with default "electron-packager" bundler:
[ia32|x64|armv7l|arm64|mips64el|all]
- with "electron-builder" bundler:
[ia32|x64|armv7l|arm64|all]
ONLY for electron-builder (when using "publish" parameter):
--publish, -P Publish options [onTag|onTagOrDraft|always|never]
- see https://www.electron.build/configuration/publish
Quasar CLI可以将所有东西封装在一起,并优化您的生产版本的应用。 它可以缩减源代码、提取vendor组件、利用浏览器缓存等等。
# Build a SPA for production
$ quasar build
# ...or
$ quasar build -m spa
# Build a SSR for production
$ quasar build -m ssr
# Build a PWA for production
$ quasar build -m pwa
# Build a BEX for production
$ quasar build -m bex
# Build a Mobile App (through Cordova)
$ quasar build -m cordova -T [android|ios]
# or the short form:
$ quasar build -m [android|ios]
# Build an Electron App for production
$ quasar build -m electron
# passing extra parameters and/or options to
# underlying "cordova" executable:
$ quasar build -m ios -- some params --and options --here
# Create a production build with ability to debug it
# (has source-maps and code is NOT minified)
$ quasar build -d [-m <mode>]
清理
清理构建资源:
$ quasar clean
新建
生成组件、页面、布局、Vuex存储。
TIP
此命令只是一个辅助程序,以便快速搭建页面/布局/组件/ vuex存储模块。 您不需要使用它,但在您不知道如何开始时可以帮助您。
$ quasar new -h
Description
Quickly scaffold a page/layout/component/store module.
Usage
$ quasar new <p|page> [-f <option>] <page_file_name>
$ quasar new <l|layout> [-f <option>] <layout_file_name>
$ quasar new <c|component> [-f <option>] <component_file_name>
$ quasar new <b|boot> [-f ts] <boot_name>
$ quasar new <s|store> [-f ts] <store_module_name>
# Examples:
# Create src/pages/MyNewPage.vue:
$ quasar new p MyNewPage
# Create src/pages/MyNewPage.vue and src/pages/OtherPage.vue:
$ quasar new p MyNewPage OtherPage
# Create src/layouts/shop/Checkout.vue
$ quasar new layout shop/Checkout.vue
# Create src/layouts/shop/Checkout.vue with TypeScript options API
$ quasar new layout -f ts-options shop/Checkout.vue
# Create a store with TypeScript support
$ quasar new store -f ts myStore
Options
--help, -h Displays this message
--format -f <option> (optional) Use a supported format for the template
Option can be:
* ts-options - TS options API
* ts-composition - TS component API
* ts-class - TS class style syntax
* ts - use for TS boot file and store modules only
模式
$ quasar mode -h
Description
Add/Remove support for PWA / BEX / Cordova / Capacitor / Electron modes.
Usage
$ quasar mode [add|remove] [pwa|ssr|bex|cordova|capacitor|electron] [--yes]
# determine what modes are currently installed:
$ quasar mode
Options
--yes, -y Skips the "Are you sure?" question
when removing a Quasar mode
--help, -h Displays this message
使用CLI初始化项目时,可以构建SPA(单页网站/应用)、SSR(服务器端渲染网站/应用,可选的PWA客户端接管)、PWA(渐进式Web应用)、移动应用(通过Cordova) 和/或Electron应用。 在开发SSR\PWA、Cordova或Electron时,需要安装这些模式。 如果您发出“quasar dev”或“quasar build”,它们将自动安装。
这些模式将在您的项目中添加一个“src- *”文件夹,其中包含非常具体的代码:
文件夹 | 模式 | 说明 |
---|---|---|
src-ssr | ssr | 包含生产环境Node服务器文件。 |
src-pwa | pwa | 包含您可以调整的Service Worker文件。 |
src-cordova | cordova | 是一个Cordova项目文件夹,将使用您的’src’作为内容。从此文件夹中调整Cordova配置,添加/删除平台,启动画面,Cordova插件等。不要触摸“src-cordova/www”文件夹,因为它会在每个版本中被覆盖。 |
src-electron | electron | 具有主electron线程的代码。渲染器线程将成为’src’中的应用程序。 |
src-bex | bex | 包含浏览器扩展模式的特定文件。 |
如果由于某种原因您决定不需要某种模式,则可以将其删除。这将永久删除相应的“src-*”文件夹。
$ quasar mode remove pwa
描述
此命令对于描述项目正在使用的任何Quasar组件/指令/插件的API非常有用。 它特定于您的项目文件夹中安装的Quasar版本。
例子: $ quasar describe QIcon
, $ quasar describe TouchPan
, $ quasar describe Cookies
.
$ quasar describe -h
Description
Describes a component API for project's Quasar version being used
Usage
$ quasar describe <component/directive/Quasar plugin>
# display everything:
$ quasar describe QIcon
# displaying only props:
$ quasar describe QIcon -p
# displaying props and methods only:
$ quasar describe QIcon -p -m
# filtering by "si":
$ quasar describe QIcon -f si
# filtering only props by "co":
$ quasar describe QIcon -p -f co
# Open docs URL:
$ quasar describe QIcon -d
Options
--filter, -f <filter> Filters the API
--props, -p Displays the API props
--slots, -s Displays the API slots
--methods, -m Displays the API methods
--events, -e Displays the API events
--value, -v Displays the API value
--arg, -a Displays the API arg
--modifiers, -M Displays the API modifiers
--injection, -i Displays the API injection
--quasar, -q Displays the API quasar conf options
--help, -h Displays this message
$ quasar describe QIcon
Describing QIcon component API
Description is based on your project's Quasar version
Properties
name (String)
Description: Name of the icon, following Quasar convention
Examples:
map
ion-add
color (String)
Description: Color name for component from the Quasar Color Palette
Examples:
primary
teal-10
size (String)
Description: Size in CSS units, including unit name
Examples:
16px
2rem
left (Boolean)
Description: Apply a standard margin on the left side. Useful if icon is on the right side of something.
right (Boolean)
Description: Apply a standard margin on the right side. Useful if icon is on the left side of something.
Slots
default
Suggestions: QTooltip or QMenu
Scoped Slots
*No scoped slots*
Events
*No events*
Methods
*No methods*
检查
此命令可用于检查Quasar CLI生成的Webpack配置。
$ quasar inspect -h
Description
Inspect Quasar generated Webpack config
Usage
$ quasar inspect
$ quasar inspect -c build
$ quasar inspect -m electron -p 'module.rules'
Options
--cmd, -c Quasar command [dev|build] (default: dev)
--mode, -m App mode [spa|ssr|pwa|cordova|electron] (default: spa)
--depth, -d Number of levels deep (default: 5)
--path, -p Path of config in dot notation
Examples:
-p module.rules
-p plugins
--help, -h Displays this message
扩展
此命令用于管理应用扩展.
$ quasar ext -h
Description
Manage Quasar App Extensions
Usage
# display list of installed extensions
$ quasar ext
# Add Quasar App Extension
$ quasar ext add <ext-id>
# Remove Quasar App Extension
$ quasar ext remove <ext-id>
# Add Quasar App Extension, but
# skip installing the npm package
# (assumes it's already installed)
$ quasar ext invoke <ext-id>
# Remove Quasar App Extension, but
# skip uninstalling the npm package
$ quasar ext uninvoke <ext-id>
Options
--help, -h Displays this message
运行
此命令用于运行您已安装到项目文件夹中的应用扩展提供的命令。
$ quasar run -h
Description
Run app extension provided commands
Usage
$ quasar run <extension-id> <cmd> [args, params]
$ quasar <extension-id> <cmd> [args, params]
$ quasar run iconify create pic -s --mark some_file
$ quasar iconify create pic -s --mark some_file
# Note: "iconify" is an example and not a real extension.
# Looks for installed extension called "iconify"
# (quasar-app-extension-iconify extension package)
# and runs its custom defined "create" command
# with "pic" argument and "-s --mark some_file" params
Options
--help, -h Displays this message
服务
这个命令也可以在生产环境中使用,它由全局安装的@quasar/cli
包提供。
$ quasar serve -h
Description
Start a HTTP(S) server on a folder.
Usage
$ quasar serve [path]
$ quasar serve . # serve current folder
If you serve a SSR folder built with the CLI then
control is yielded to /index.js and params have no effect.
Options
--port, -p Port to use (default: 4000)
--hostname, -H Address to use (default: 0.0.0.0)
--gzip, -g Compress content (default: true)
--silent, -s Suppress log message
--colors Log messages with colors (default: true)
--open, -o Open browser window after starting
--cache, -c <number> Cache time (max-age) in seconds;
Does not apply to /service-worker.js
(default: 86400 - 24 hours)
--micro, -m <seconds> Use micro-cache (default: 1 second)
--history Use history api fallback;
All requests fallback to /index.html,
unless using "--index" parameter
--index, -i <file> History mode (only!) index url path
(default: index.html)
--https Enable HTTPS
--cert, -C [path] Path to SSL cert file (Optional)
--key, -K [path] Path to SSL key file (Optional)
--proxy <file.js> Proxy specific requests defined in file;
File must export Array ({ path, rule })
See example below. "rule" is defined at:
https://github.com/chimurai/http-proxy-middleware
--cors Enable CORS for all requests
--help, -h Displays this message
Proxy file example
module.exports = [
{
path: '/api',
rule: { target: 'http://www.example.org' }
}
]
--> will be transformed into app.use(path, httpProxyMiddleware(rule))
定制Node服务器
构建SPA或PWA时,可分发文件夹可由任何静态网络服务器提供服务。 为了测试它(假设您没有特定的publicPath或者没有使用Vue 路由的“history”模式),您可以使用“http-server”npm软件包。
或者你可以建立你自己的服务器。 这里有些例子:
// when using default Vue Router "hash" mode
const
express = require('express'),
serveStatic = require('serve-static'),
port = process.env.PORT || 5000
const app = express()
// attackers can use this header to detect apps running Express
// and then launch specifically-targeted attacks
app.disable('x-powered-by')
app.use(serveStatic(...path-to-dist...))
app.listen(port)
// when using Vue Router "history" mode
const
express = require('express'),
serveStatic = require('serve-static'),
history = require('connect-history-api-fallback'),
port = process.env.PORT || 5000
const app = express()
// attackers can use this header to detect apps running Express
// and then launch specifically-targeted attacks
app.disable('x-powered-by')
app.use(history())
app.use(serveStatic(...path-to-dist...))
app.listen(port)
如果您需要API的URL重写,或者只需要代理您的API请求,那么您可以使用“http-proxy-middleware”软件包:
// add this to one of the two previous examples:
const { createProxyMiddleware } = require('http-proxy-middleware')
// ...
app.use('/api', createProxyMiddleware({
target: `http://my-api.com:5050`,
pathRewrite: {"^/api" : ""}
}))
// then app.listen(...)
最后,运行以下文件之一:
$ node my-server.js