继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Vue3阿里系UI组件入门教程

慕标琳琳
关注TA
已关注
手记 315
粉丝 18
获赞 140
概述

本文介绍了Vue3的基本概念、核心特性和安装方法,并详细说明了如何将Vue3与阿里系UI组件库结合使用。Vue3带来了诸多性能改进和新特性,而阿里系UI组件库提供了丰富的组件和强大的定制能力,支持Vue3的集成,使得开发者能够轻松构建高质量的用户界面。

Vue3简介与安装
Vue3的基本概念

Vue.js 是一个用于构建用户界面的渐进式框架。它遵循模块化设计,允许开发者逐步将 Vue 引入现有项目。Vue 3 是 Vue.js 的最新版本,它带来了许多性能改进、TypeScript 支持的增强、更好的响应式系统等特性。

核心特性

  1. 响应式系统:Vue 3 通过 Proxy 对象实现响应式,相比 Vue 2 的 Object.defineProperty,新版本的响应式系统性能更好、支持更丰富的功能。
  2. Composition API:Composition API 提供了一种更灵活的方式来组织和重用逻辑代码,这对于开发复杂的组件非常有帮助。
  3. 更好的模板解析器:Vue 3 的模板解析器更高效,能够减少编译时间。
  4. Teleport 和 Fragments:这些新特性为开发更复杂的用户界面提供了更多可能性。
  5. Tree Shaking:Vue 3 的核心库体积更小,可以更好地进行无用代码的剔除,使得最终打包的文件更小。

模板与组件

Vue 使用模板语法来描述视图,模板中可以包含 HTML 与 Vue 特有的指令,例如 v-ifv-forv-model。Vue 应用通常由一个或多个组件构成,每个组件都是一个 Vue 实例,拥有自己的状态和生命周期。

Vue3的安装与配置

要开始使用 Vue 3,首先需要安装 Vue CLI。Vue CLI 提供了一套完整的工具链,可以用来快速搭建 Vue 项目,并支持多种构建配置。

安装 Vue CLI

  1. 全局安装 Vue CLI:

    npm install -g @vue/cli
  2. 创建一个新的 Vue 项目:

    vue create my-project

    在选择模板时,可以选择最新版本的 Vue 3。

  3. 添加 Vue 3 支持:

    如果没有直接选择 Vue 3 模板,可以手动升级到 Vue 3。首先,进入项目目录并打开 package.json 文件,将 dependencies 下的 vuevue-template-compiler 版本升级为最新版本,并添加 vue-routervuex(如果需要的话)。然后执行 npm install 命令安装依赖。

  4. 初始化项目:

    cd my-project
    npm run serve

    这将启动开发服务器,并在浏览器中打开一个新的页面来预览项目。

项目的初始化和配置

创建项目后,需要在 main.js 中引入 Vue 和路由管理器,并在 App.vue 中定义根组件。

// main.js
import { createApp } from 'vue';
import App from './App.vue';
import router from './router';

const app = createApp(App);
app.use(router);
app.mount('#app');
<!-- App.vue -->
<template>
  <div id="app">
    <router-view></router-view>
  </div>
</template>

<script>
export default {
  name: 'App'
}
</script>
创建第一个Vue3项目

创建项目后,可以编写一个简单的 Vue 组件来熟悉基本语法。创建一个新的 Vue 文件(例如 HelloWorld.vue),并编写以下代码:

<template>
  <div class="hello">
    <h1>{{ msg }}</h1>
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  props: {
    msg: String
  }
}
</script>

<style scoped>
.hello {
  color: #42b983;
}
</style>

App.vue 中引入并使用该组件:

<template>
  <div id="app">
    <HelloWorld msg="Welcome to Your Vue.js App"/>
  </div>
</template>

<script>
import HelloWorld from './components/HelloWorld.vue'

export default {
  name: 'App',
  components: {
    HelloWorld
  }
}
</script>

上述代码展示了一个简单的单文件组件(SFC)结构,包括模板、脚本和样式部分。在组件中,可以使用模板语法来绑定数据和事件,组件之间的通信通过属性传递和事件监听来完成。

阿里系UI组件库介绍
阿里系UI组件库的概述

阿里系UI组件库是一个广泛使用的前端组件库,它提供了丰富的组件来帮助开发者构建高质量的用户界面。这些组件分为基础组件、导航组件、数据展示组件、表单组件等多种类型,涵盖了大部分前端开发中常用的交互场景。阿里系UI组件库支持 Vue 3,使得开发者可以轻松地将其集成到自己的项目中。

特点

  1. 丰富的组件:涵盖常用的界面组件,如按钮、输入框、表格、导航等。
  2. 高性能:经过严格优化,保证了在各种复杂场景中的性能。
  3. 丰富的主题和样式:提供了多种预设样式和主题,可轻松适应各种设计要求。
  4. 强大的定制能力:允许开发者根据项目需求自定义样式和功能。
  5. 完善的文档和社区支持:提供了详细的操作指南和丰富的示例代码,方便开发者学习和使用。

安装与引入

首先,安装阿里系UI组件库:

npm install ant-design-vue

然后在项目中引入组件库:

// main.js
import { createApp } from 'vue';
import App from './App.vue';
import Antd from 'ant-design-vue';
import 'ant-design-vue/dist/antd.css';

const app = createApp(App);
app.use(Antd).mount('#app');

在上述代码中,首先引入了 ant-design-vue 库及其样式文件。通过 app.use(Antd),将组件库注册到 Vue 应用中,最后调用 mount 方法挂载到对应的 DOM 节点。

常见组件的使用方法

阿里系UI组件库提供了众多组件,这里以几个基础组件为例,展示其使用方法:

按钮组件

阿里系UI组件库中的按钮组件分为多种类型,如默认按钮、主要按钮、危险按钮等。下面展示一个简单的按钮组件实例:

<template>
  <a-button type="primary">主要按钮</a-button>
  <a-button type="danger">危险按钮</a-button>
</template>

<script>
import { defineComponent } from 'vue';
import { Button } from 'ant-design-vue';

export default defineComponent({
  components: {
    AButton: Button
  }
})
</script>

输入框组件

阿里系UI组件库中的输入框支持不同类型的输入,包括文本输入、密码输入等。下面是一个简单的输入框组件实例:

<template>
  <a-input placeholder="请输入内容" />
</template>

<script>
import { defineComponent } from 'vue';
import { Input } from 'ant-design-vue';

export default defineComponent({
  components: {
    AInput: Input
  }
});
</script>

表格组件

表格组件用于展示和操作表格数据,支持排序、筛选、分页等功能。下面展示一个简单的表格组件实例:

<template>
  <a-table :columns="columns" :data-source="data" />
</template>

<script>
import { defineComponent } from 'vue';
import { Table } from 'ant-design-vue';

export default defineComponent({
  components: {
    ATable: Table
  },
  data() {
    return {
      columns: [
        {
          title: '姓名',
          dataIndex: 'name'
        },
        {
          title: '年龄',
          dataIndex: 'age'
        }
      ],
      data: [
        { name: '张三', age: 25 },
        { name: '李四', age: 30 }
      ]
    };
  }
});
</script>

菜单导航组件

菜单导航组件通常用于构建网站的导航栏。下面展示一个简单的菜单导航组件实例:

<template>
  <a-menu mode="horizontal">
    <a-menu-item key="1">首页</a-menu-item>
    <a-menu-item key="2">关于我们</a-menu-item>
    <a-sub-menu key="3">
      <template #title>产品</template>
      <a-menu-item key="31">产品A</a-menu-item>
      <a-menu-item key="32">产品B</a-menu-item>
    </a-sub-menu>
  </a-menu>
</template>

<script>
import { defineComponent } from 'vue';
import { Menu, MenuDivider, MenuItem, SubMenu } from 'ant-design-vue';

export default defineComponent({
  components: {
    AMenu: Menu,
    AMenuItem: MenuItem,
    ASubMenu: SubMenu
  }
});
</script>
常用UI组件详解
按钮组件的使用

按钮组件是 UI 库中最常用的组件之一。阿里系UI组件库提供了不同类型的按钮,如默认按钮、主要按钮、危险按钮等,以及不同大小的按钮。

主要按钮

主要按钮用于强调重要操作,有蓝色背景,默认带有阴影效果。

<template>
  <a-button type="primary">主要按钮</a-button>
</template>

<script>
import { Button } from 'ant-design-vue';

export default {
  components: {
    AButton: Button
  }
};
</script>

危险按钮

危险按钮用于表示危险操作,如删除、取消等,通常带有红色背景。

<template>
  <a-button type="danger">危险按钮</a-button>
</template>

<script>
import { Button } from 'ant-design-vue';

export default {
  components: {
    AButton: Button
  }
};
</script>

自定义按钮样式

除了使用预定义的按钮类型,还可以通过 style 属性自定义按钮样式。

<template>
  <a-button style="background-color: #ff6600; color: white">自定义颜色按钮</a-button>
</template>

<script>
import { Button } from 'ant-design-vue';

export default {
  components: {
    AButton: Button
  }
};
</script>

按钮尺寸

阿里系UI组件库提供了多种按钮尺寸,可以通过 size 属性来指定按钮大小。

<template>
  <a-button type="primary" size="large">大号按钮</a-button>
  <a-button type="primary" size="middle">默认按钮</a-button>
  <a-button type="primary" size="small">小号按钮</a-button>
</template>

<script>
import { Button } from 'ant-design-vue';

export default {
  components: {
    AButton: Button
  }
};
</script>

可点按钮

除了普通的按钮,还可以使用 a-button-group 组件来创建可点按钮组。

<template>
  <a-button-group>
    <a-button type="primary">左</a-button>
    <a-button type="primary">中</a-button>
    <a-button type="primary">右</a-button>
  </a-button-group>
</template>

<script>
import { ButtonGroup, Button } from 'ant-design-vue';

export default {
  components: {
    AButtonGroup: ButtonGroup,
    AButton: Button
  }
};
</script>
输入框组件的使用

输入框组件用于用户输入数据,支持文本输入、密码输入等。阿里系UI组件库提供了丰富的输入框组件,可以满足不同场景的需求。

文本输入框

文本输入框是最基本的输入组件,提供了基本的输入功能。

<template>
  <a-input placeholder="请输入文本" />
</template>

<script>
import { Input } from 'ant-design-vue';

export default {
  components: {
    AInput: Input
  }
};
</script>

密码输入框

密码输入框用于输入敏感信息,如密码等,输入内容会被自动隐藏。

<template>
  <a-input placeholder="请输入密码" type="password" />
</template>

<script>
import { Input } from 'ant-design-vue';

export default {
  components: {
    AInput: Input
  }
};
</script>

搜索框

搜索框用于搜索功能,通常附带一个搜索按钮。

<template>
  <a-input-search placeholder="请输入搜索内容" enter-button="搜索" @search="onSearch" />
</template>

<script>
import { InputSearch } from 'ant-design-vue';

export default {
  components: {
    AInputSearch: InputSearch
  },
  methods: {
    onSearch(value) {
      console.log('搜索内容:', value);
    }
  }
};
</script>

自定义输入框样式

通过 addonBeforeaddonAfter 属性,可以添加前置和后置内容。

<template>
  <a-input placeholder="请输入内容" addon-before="¥" addon-after="元" />
</template>

<script>
import { Input } from 'ant-design-vue';

export default {
  components: {
    AInput: Input
  }
};
</script>

占位符与禁用状态

可以通过 placeholder 属性指定输入框的占位符,使用 disabled 属性禁用输入框。

<template>
  <a-input placeholder="不可编辑" disabled />
</template>

<script>
import { Input } from 'ant-design-vue';

export default {
  components: {
    AInput: Input
  }
};
</script>

输入框尺寸

输入框尺寸可以通过 size 属性来指定。

<template>
  <a-input placeholder="请输入内容" size="large" />
  <a-input placeholder="请输入内容" size="default" />
  <a-input placeholder="请输入内容" size="small" />
</template>

<script>
import { Input } from 'ant-design-vue';

export default {
  components: {
    AInput: Input
  }
};
</script>
表格组件的使用

表格组件用于展示和操作表格数据,支持排序、筛选、分页等功能。阿里系UI组件库提供了丰富的表格组件,可以满足各种需求。

基本表格

基本表格组件用来展示数据列表。

<template>
  <a-table :columns="columns" :data-source="data" />
</template>

<script>
import { defineComponent } from 'vue';
import { Table } from 'ant-design-vue';

export default defineComponent({
  components: {
    ATable: Table
  },
  data() {
    return {
      columns: [
        { title: '姓名', dataIndex: 'name' },
        { title: '年龄', dataIndex: 'age' }
      ],
      data: [
        { name: '张三', age: 25 },
        { name: '李四', age: 30 }
      ]
    };
  }
});
</script>

表格分页

表格组件可以实现分页功能,方便用户通过翻页查看大量数据。

<template>
  <a-table :columns="columns" :data-source="data" :pagination="pagination" />
</template>

<script>
import { defineComponent } from 'vue';
import { Table } from 'ant-design-vue';

export default defineComponent({
  components: {
    ATable: Table
  },
  data() {
    return {
      columns: [
        { title: '姓名', dataIndex: 'name' },
        { title: '年龄', dataIndex: 'age' }
      ],
      data: [
        { name: '张三', age: 25 },
        { name: '李四', age: 30 }
      ],
      pagination: {
        pageSize: 5
      }
    };
  }
});
</script>

表格排序

表格组件可以实现列的排序功能,方便用户根据不同的列进行数据排序。

<template>
  <a-table :columns="columns" :data-source="data" :row-key="rowKey" :sorter="true" />
</template>

<script>
import { defineComponent } from 'vue';
import { Table } from 'ant-design-vue';

export default defineComponent({
  components: {
    ATable: Table
  },
  data() {
    return {
      columns: [
        { title: '姓名', dataIndex: 'name', sorter: true },
        { title: '年龄', dataIndex: 'age', sorter: true }
      ],
      data: [
        { name: '张三', age: 25 },
        { name: '李四', age: 30 }
      ]
    };
  },
  methods: {
    rowKey(record) {
      return record.name;
    }
  }
});
</script>
项目实例
构建简单的Vue3应用

登录页面

可以使用阿里系UI组件库构建一个简单的登录页面。以下是一个登录页面的示例:

<template>
  <a-form :model="form" :label-col="{ span: 6 }" :wrapper-col="{ span: 18 }" @finish="handleFinish" @finishFailed="handleFinishFailed">
    <a-form-item label="用户名" name="username" :rules="[{ required: true, message: '请输入用户名' }]">
      <a-input v-model:value="form.username" />
    </a-form-item>
    <a-form-item label="密码" name="password" :rules="[{ required: true, message: '请输入密码' }]">
      <a-input v-model:value="form.password" type="password" />
    </a-form-item>
    <a-form-item :wrapper-col="{ offset: 6, span: 18 }">
      <a-button type="primary" html-type="submit">登录</a-button>
    </a-form-item>
  </a-form>
</template>

<script>
import { defineComponent } from 'vue';
import { Form, Input, Button } from 'ant-design-vue';

export default defineComponent({
  components: {
    AForm: Form,
    AFormItem: Form.Item,
    AInput: Input,
    AButton: Button
  },
  data() {
    return {
      form: {
        username: '',
        password: ''
      }
    };
  },
  methods: {
    handleFinish(values) {
      console.log('登录成功');
    },
    handleFinishFailed(errors) {
      console.log('登录失败', errors);
    }
  }
});
</script>

数据展示页面

可以使用阿里系UI组件库构建一个简单的数据展示页面,展示用户列表。以下是一个数据展示页面的示例:

<template>
  <a-table :columns="columns" :data-source="data" :row-key="rowKey" :sorter="true" />
</template>

<script>
import { defineComponent } from 'vue';
import { Table } from 'ant-design-vue';

export default defineComponent({
  components: {
    ATable: Table
  },
  data() {
    return {
      columns: [
        { title: '姓名', dataIndex: 'name' },
        { title: '年龄', dataIndex: 'age' },
        { title: '地址', dataIndex: 'address' }
      ],
      data: [
        { name: '张三', age: 25, address: '北京市' },
        { name: '李四', age: 30, address: '上海市' }
      ]
    };
  },
  methods: {
    rowKey(record) {
      return record.name;
    }
  }
});
</script>
``

# 配置与定制UI样式

## 全局样式配置

可以通过在主文件中引入全局样式来覆盖默认样式,例如:

```javascript
import 'ant-design-vue/dist/antd.css';

进一步自定义样式,可以在项目根目录的 public/index.htmlsrc/App.vue 中引入自定义样式文件。

<!-- public/index.html -->
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>Vue3 AliUI Demo</title>
    <link rel="stylesheet" href="style.css" />
  </head>
  <body>
    <div id="app"></div>
  </body>
</html>
/* style.css */
body {
  background-color: #f8f8f8;
}
自定义组件样式

在组件内部,可以通过 stylescoped 样式来定制组件样式:

<template>
  <a-button style="background-color: #ff6600; color: white">自定义颜色按钮</a-button>
</template>

<script>
import { Button } from 'ant-design-vue';

export default {
  components: {
    AButton: Button
  }
};
</script>

<style scoped>
/* 自定义样式 */
</style>
样式覆盖技巧

如果需要覆盖组件的默认样式,可以使用 CSS 选择器来实现:

/* 覆盖默认样式 */
.ant-btn-primary {
  background-color: #ff6600;
  color: white;
}
小结与后续学习建议

本文详细介绍了如何使用 Vue 3 和阿里系UI组件库构建前端应用,包括 Vue 3 的安装与配置、阿里系UI组件库的使用方法、常用组件的使用方法以及项目实例。通过这些内容,开发者可以快速上手使用 Vue 3 和阿里系UI组件库。建议进一步学习 Vue 3 的 Composition API、响应式系统等高级特性,并探索更多阿里系UI组件库的功能,以便更好地构建高质量的用户界面。

学习资源推荐
打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP