VUE3套用组件库快速开发(以Element Plus为例)二

接上文,接下来配置第五步

  1. 改写app.vue
js 复制代码
<template>
  <div class="common-layout">
    <el-container>
      <el-header
        style="background-color: #409EFF; color: white; display: flex; align-items: center; justify-content: space-between;">
        <div style="font-weight: bold; font-size: 40px;">学习社区 2026</div>

        <el-menu mode="horizontal" background-color="#409EFF" text-color="#fff" active-text-color="#ffd04b" router
          :default-active="$route.path">
          <el-menu-item index="/">首页列表</el-menu-item>
          <el-menu-item index="/post">我要发帖</el-menu-item>
          <el-menu-item index="/about">关于</el-menu-item>
        </el-menu>
      </el-header>

      <el-main>
        <RouterView />
      </el-main>
    </el-container>
  </div>
</template>

<style>
/* 消除浏览器自带的 8px 外边距,让导航栏铺满 */
body {
  margin: 0;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}
</style>
  1. 在src/view/PostView.vue
js 复制代码
<template>
  <div style="max-width: 800px; margin: 0 auto;">
    <el-card>
      <template #header>
        <div class="card-header">
          <span>发布新讨论帖</span>
        </div>
      </template>

      <el-form :model="postForm" label-position="top">
        <el-form-item label="帖子标题">
          <el-input v-model="postForm.title" placeholder="请输入吸引人的标题" />
        </el-form-item>

        <el-form-item label="所属板块">
          <el-radio-group v-model="postForm.tag">
            <el-radio-button label="前端" />
            <el-radio-button label="后端" />
            <el-radio-button label="求职" />
            <el-radio-button label="灌水" />
          </el-radio-group>
        </el-form-item>

        <el-form-item label="帖子正文">
          <el-input
            v-model="postForm.content"
            type="textarea"
            :rows="6"
            placeholder="请分享你的学习心得..."
          />
        </el-form-item>

        <el-form-item>
          <el-button type="primary" @click="handlePublish">立即发布</el-button>
          <el-button>存为草稿</el-button>
        </el-form-item>
      </el-form>
    </el-card>
  </div>
</template>

<script setup>
import { reactive } from 'vue'
import { ElMessage } from 'element-plus'

// 使用 reactive 定义一组响应式数据
const postForm = reactive({
  title: '',
  tag: '前端',
  content: ''
})

const handlePublish = () => {
  // 简单的校验逻辑
  if (!postForm.title || !postForm.content) {
    ElMessage.warning('请填写完整内容再发布哦!')
    return
  }
  
  console.log('正在向后端发送数据...', postForm)
  ElMessage.success('发布成功!(数据已打印在控制台)')
}
</script>
  1. 更新router
js 复制代码
{
      path: '/post',
      name: 'post',
      // 这就是所谓的"懒加载",只有点击时才加载 PostView 页面
      component: () => import('../views/PostView.vue')
    }

此时访问/post页面已经有了内容

相关推荐
搬砖的阿wei8 小时前
CSS常用选择器总结
前端·css
m0_706653238 小时前
模板编译期排序算法
开发语言·c++·算法
历程里程碑8 小时前
Linxu14 进程一
linux·c语言·开发语言·数据结构·c++·笔记·算法
不当菜虚困8 小时前
windows下HSDB导出class文件报错【java.io.IOException : 系统找不到指定的路径。】
java·开发语言
lsx2024068 小时前
Vue.js 循环语句
开发语言
m0_561359678 小时前
嵌入式C++加密库
开发语言·c++·算法
2601_949833398 小时前
flutter_for_openharmony口腔护理app实战+意见反馈实现
android·javascript·flutter
j445566118 小时前
C++中的职责链模式实战
开发语言·c++·算法
m0_686041618 小时前
实时数据流处理
开发语言·c++·算法
梵刹古音8 小时前
【C语言】 字符型变量
c语言·开发语言·嵌入式