记一次vue-cli3.0 + elementui(按需引入) + typescript项目搭建过程

馮寳寳

此文章是借鉴文章加上自己的记忆结合过程记录,以备日后复习和使用。有不对或者更好方法的欢迎提出呢~

1、首先安装vue-cli3.0和typescript,如果之前有安装2.X需要先卸载
`npm i -g @vue/cli typescript`

检查typescript版本信息方法:tsc -v

2、创建vue项目
`vue create projectname`

创建项目配置:
image.png
询问是用之前保存的模板,还是默认只有babel和eslint的模板,还是自己新配置。这里选择第三项Manually select features,上下键选择,回车键确定

image.png
选择需要哪些插件

image.png
上下键移动,空格键选择,回车确定。此次选择以上配置,回车

eslint和prettier区别:

eslint 是一个Javascript Linter,帮助我们规范代码质量,提高团队开发效率。 虽然能帮助我们提高代码质量,但并不能完全统一编码风格,因为这些代码规范的重点并不在代码风格上,虽然有一定的限制。
prettier 是一个能够统一团队编码风格的工具,能够极大的提高团队执行效率,统一的编码风格能很好的保证代码的可读性。

image.png
这里是询问是否使用 class风格的组件语法,为了更方便地使用 TypeScript,我们选择 Y,回车就行。

image.png
当我们不知道选择那个选项时,可以直接按enter,使用默认选项。

image.png
这里是询问是否使用 routerhistory模式,如果选择是,在生产环境中,服务端需要为索引回退做适当的配置。这个对我们的 demo 没有影响,同样按enter使用默认选项。

image.png
这里是选择CSS预处理器,可以自行选择一种

image.png
这里是选择代码检查工具,参考的文章推荐使用 ESLint + Prettier。原因是 Prettier 不仅可以格式化js代码,还可以格式化 cssvue模板文件中 template 部分的代码。

image.png
这里是选择什么时候进行代码格式化,选择 Lint on save

image.png
这里是询问在什么地方配置 Babel,PostCSS, ESLint 等

In dedicated config files 在专门的配置文件中
In package.json 配置在package.json

我们选择 In dedicated config files 

image.png
**这里是询问:是否保存本次所选的配置,方便下次搭建项目时复用。
我们直接跳过,按enter,等待项目初始化完成就可以了。**

3、配置 .prettierrc文件。

**代码检查工具选择ESLint + Prettier时,ESLintPrettier相冲突的配置项会被关闭,采用的是Prettier的配置项。这个文档,列出了ESLintPrettier冲突的配置项。
Prettier会将字符串格式化为双引号,并在句尾自动添加分号。如果要配置使用单引号和无分号结尾可以这么配置:

在项目根目录下(与 package.json 同级目录)创建一个 .prettierrc.js文件,并加上以下配置**
module.exports = {
    singleQuote: true,
    semi: false
}

修改.eslintrc.js文件,加上这行代码就可以了:
image.png
检查是否配置成功,打开main.ts
image.png
ctrl+s查看结果
image.png
起作用,配置成功,下面来安装elementui
4、安装elementui
vue add element
image.png
询问是全部引入还是按需引入,上下键选择第二个,按需引入,回车

image.png
第一个 中文 回车(这一块我也不知道什么意思,请问有补充的吗?我只知道是中文的意思)

然后就回发现 项目中src下多了一个文件夹,main.ts也多了一行代码
image.png
elementui.js只给出了一个例子,全部数据以下是翻阅其他文档整理给出的,供参考

import Vue from 'vue';
import {
        Pagination,
        Dialog,
        Autocomplete,
        Dropdown,
        DropdownMenu,
        DropdownItem,
        Menu,
        Submenu,
        MenuItem,
        MenuItemGroup,
        Input,
        InputNumber,
        Radio,
        RadioGroup,
        RadioButton,
        Checkbox,
        CheckboxButton,
        CheckboxGroup,
        Switch,
        Select,
        Option,
        OptionGroup,
        Button,
        ButtonGroup,
        Table,
        TableColumn,
        DatePicker,
        TimeSelect,
        TimePicker,
        Popover,
        Tooltip,
        Breadcrumb,
        BreadcrumbItem,
        Form,
        FormItem,
        Tabs,
        TabPane,
        Tag,
        Tree,
        Alert,
        Slider,
        Icon,
        Row,
        Col,
        Upload,
        Progress,
        Spinner,
        Badge,
        Card,
        Rate,
        Steps,
        Step,
        Carousel,
        CarouselItem,
        Collapse,
        CollapseItem,
        Cascader,
        ColorPicker,
        Transfer,
        Container,
        Header,
        Aside,
        Main,
        Footer,
        Timeline,
        TimelineItem,
        Link,
        Divider,
        Image,
        Calendar,
        Backtop,
        PageHeader,
        CascaderPanel,
        Loading,
        MessageBox,
        Message,
        Notification
} from 'element-ui'
Vue.use(Pagination)
Vue.use(Dialog)
Vue.use(Autocomplete)
Vue.use(Dropdown)
Vue.use(DropdownMenu)
Vue.use(DropdownItem)
Vue.use(Menu)
Vue.use(Submenu)
Vue.use(MenuItem)
Vue.use(MenuItemGroup)
Vue.use(Input)
Vue.use(InputNumber)
Vue.use(Radio)
Vue.use(RadioGroup)
Vue.use(RadioButton)
Vue.use(Checkbox)
Vue.use(CheckboxButton)
Vue.use(CheckboxGroup)
Vue.use(Switch)
Vue.use(Select)
Vue.use(Option)
Vue.use(OptionGroup)
Vue.use(Button)
Vue.use(ButtonGroup)
Vue.use(Table)
Vue.use(TableColumn)
Vue.use(DatePicker)
Vue.use(TimeSelect)
Vue.use(TimePicker)
Vue.use(Popover)
Vue.use(Tooltip)
Vue.use(Breadcrumb)
Vue.use(BreadcrumbItem)
Vue.use(Form)
Vue.use(FormItem)
Vue.use(Tabs)
Vue.use(TabPane)
Vue.use(Tag)
Vue.use(Tree)
Vue.use(Alert)
Vue.use(Slider)
Vue.use(Icon)
Vue.use(Row)
Vue.use(Col)
Vue.use(Upload)
Vue.use(Progress)
Vue.use(Spinner)
Vue.use(Badge)
Vue.use(Card)
Vue.use(Rate)
Vue.use(Steps)
Vue.use(Step)
Vue.use(Carousel)
Vue.use(CarouselItem)
Vue.use(Collapse)
Vue.use(CollapseItem)
Vue.use(Cascader)
Vue.use(ColorPicker)
Vue.use(Transfer)
Vue.use(Container)
Vue.use(Header)
Vue.use(Aside)
Vue.use(Main)
Vue.use(Footer)
Vue.use(Timeline)
Vue.use(TimelineItem)
Vue.use(Link)
Vue.use(Divider)
Vue.use(Image)
Vue.use(Calendar)
Vue.use(Backtop)
Vue.use(PageHeader)
Vue.use(CascaderPanel)
Vue.use(Loading.directive)
Vue.prototype.$loading = Loading.service
Vue.prototype.$msgbox = MessageBox
Vue.prototype.$alert = MessageBox.alert
Vue.prototype.$confirm = MessageBox.confirm
Vue.prototype.$prompt = MessageBox.prompt
Vue.prototype.$notify = Notification
Vue.prototype.$message = Message

以上是项目搭建配置过程

阅读 2.1k

人生,可以追求,切莫攀比。你虚荣可以,但一定要靠自己。

21 声望
0 粉丝
0 条评论

人生,可以追求,切莫攀比。你虚荣可以,但一定要靠自己。

21 声望
0 粉丝
文章目录
宣传栏