記一次vue-cli3.0 + elementui(按需引入) + typescript項目搭建過程

此文章是借鑑文章加上本身的記憶結合過程記錄,以備往後複習和使用。有不對或者更好方法的歡迎提出呢~css

一、首先安裝vue-cli3.0和typescript,若是以前有安裝2.X須要先卸載html

`npm i -g @vue/cli typescript`

檢查typescript版本信息方法:tsc -v
二、建立vue項目vue

`vue create projectname`

建立項目配置:
image.png
詢問是用以前保存的模板,仍是默認只有babel和eslint的模板,仍是本身新配置。這裏選擇第三項Manually select features,上下鍵選擇,回車鍵肯定
image.png
選擇須要哪些插件
image.png
上下鍵移動,空格鍵選擇,回車肯定。這次選擇以上配置,回車
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 等git

  • In dedicated config files 在專門的配置文件中
  • In package.json 配置在package.json文件中

咱們選擇 In dedicated config files 
image.png
這裏是詢問:是否保存本次所選的配置,方便下次搭建項目時複用。
咱們直接跳過,按enter,等待項目初始化完成就能夠了。
三、配置 .prettierrc文件。
代碼檢查工具選擇ESLint + Prettier時,ESLintPrettier相沖突的配置項會被關閉,採用的是Prettier的配置項。這個文檔,列出了ESLintPrettier衝突的配置項。
Prettier會將字符串格式化爲雙引號,並在句尾自動添加分號。若是要配置使用單引號和無分號結尾能夠這麼配置:github

在項目根目錄下(與 package.json 同級目錄)建立一個 .prettierrc.js文件,並加上如下配置
module.exports = {
    singleQuote: true,
    semi: false
}

修改.eslintrc.js文件,加上這行代碼就能夠了:
image.png
檢查是否配置成功,打開main.ts
image.png
ctrl+s查看結果
image.png
起做用,配置成功,下面來安裝elementui
四、安裝elementui
vue add element
image.png
詢問是所有引入仍是按需引入,上下鍵選擇第二個,按需引入,回車
image.png
第一個 中文 回車(這一塊我也不知道什麼意思,請問有補充的嗎?我只知道是中文的意思)vue-cli

而後就回發現 項目中src下多了一個文件夾,main.ts也多了一行代碼
image.png
elementui.js只給出了一個例子,所有數據如下是翻閱其餘文檔整理給出的,供參考typescript

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

以上是項目搭建配置過程npm

相關文章
相關標籤/搜索