当前位置: 首页 > news >正文

网站开发教程图文网页界面设计ppt

网站开发教程图文,网页界面设计ppt,如何制作自媒体短视频,有网站做点什么好文章目录 核心内容1.大事件项目介绍2.大事件项目创建3.Eslint配置代码风格4.配置代码检查工作流问题: pnpm lint是全量检查,耗时问题,历史问题 5.目录调整6.vue-router4 路由代码解析7.引入 Element Plus 组件库8.Pinia 构建仓库 和 持久化9.Pinia 仓库统一管理 核心内容 Vue3… 文章目录 核心内容1.大事件项目介绍2.大事件项目创建3.Eslint配置代码风格4.配置代码检查工作流问题: pnpm lint是全量检查,耗时问题,历史问题 5.目录调整6.vue-router4 路由代码解析7.引入 Element Plus 组件库8.Pinia 构建仓库 和 持久化9.Pinia 仓库统一管理 核心内容 Vue3 compositionAPIPinia / Pinia持久化处理Element Plus 表单校验表格处理组件封装pnpm 包管理升级Eslint prettier 更规范的配制husky Git hooks工具 代码提交之前进行校验请求模块设计/拦截器响应拦截器中的处理路由设计VueRouter4AI 大模型开发一整个项目模块 1.大事件项目介绍 在线演示https://fe-bigevent-web.itheima.net/login 接口文档https://apifox.com/apidoc/shared-26c67aee-0233-4d23-aab7-08448fdf95ff/api-93850835 基地址http://big-event-vue-api-t.itheima.net 2.大事件项目创建 pnpm包管理器 - 创建项目 一些优势比统类工具快2倍左右、节省磁盘空间 https://www.pnpm.cn/ 安装方式npm install -g pnpm 创建项目pnpm create vue 3.Eslint配置代码风格 配置文件 .eslintrc.cjs prettier 配置风格 https://prettier.iovue组件名称多单词组成忽略index.vueprops解构(关闭) rules: {//prettier专注于代码的美观度(格式化工具)//前置://1. 禁用格式化插件//2. 安装Eslint插件,并配置保存时自动修复prettier/prettier: [warn,{singleQuote: true, // 单引号semi: false, // 无分号printWidth: 80, // 每行宽度至多80字符trailingComma: none, // 不加对象|数组最后逗号endOfLine: auto // 换行符号不限制win mac 不一致}],//ESLint关注于规范vue/multi-word-component-names: [warn,{ignores: [index] // vue组件名称多单词组成忽略index.vue}],vue/no-setup-props-destructure: [off], // 关闭 props 解构的校验// 添加未定义变量错误提示create-vue3.6.3 关闭这里加上是为了支持下一个章节演示。no-undef: error}4.配置代码检查工作流 提交2前做代码检查 初始化 git 仓库,执行git init 即可初始化 husky 工具配置,执行 pnpm dlx husky-init pnpm install 即可 https://typicode.github.io/husky/修改.husky/pre-commit文件 -npm test pnpm lint先下载gitbash 第二步出错时可以换到安全目录执行如$ git config --global --add safe.directory C:/Users/31501/Desktop/a-a-a 还需要在git中设置账户 不然无法执行git commit -m 执行之后会提示错误 修改错误之后 再次输入 git add . git commit -m 初始化提交测试 这是才会成功添加到仓库当中 问题: pnpm lint是全量检查,耗时问题,历史问题 暂存区 eslint校验 安装 lint-staged 包 pnpm i lint-staged -Dpackage.json 配置 lint-staged 命令.husky/pre-commit文件修改 lint-staged 配置 安装 pnpm i lint-staged -D 配置 package.json {// ... 省略 ...lint-staged: {*.{js,ts,vue}: [eslint --fix]} }{scripts: {// ... 省略 ...lint-staged: lint-staged} }修改 .husky/pre-commit 文件 pnpm lint-staged 报错运行结果 31501□□ҹ□□□□ MINGW64 ~/Desktop/a-a-a (master) $ git add . warning: in the working copy of .husky/pre-commit, LF will be replaced by CRLF the next time Git touches it warning: in the working copy of package.json, LF will be replaced by CRLF the next time Git touches it warning: in the working copy of pnpm-lock.yaml, LF will be replaced by CRLF the next time Git touches it warning: in the working copy of src/main.js, LF will be replaced by CRLF the next time Git touches it31501□□ҹ□□□□ MINGW64 ~/Desktop/a-a-a (master) $ git commit -m 修改main.js的内容 a-a-a0.0.0 lint-staged C:\Users\31501\Desktop\a-a-alint-staged[STARTED] Preparing lint-staged... [COMPLETED] Preparing lint-staged... [STARTED] Running tasks for staged files... [STARTED] package.json — 4 files [STARTED] *.{js,ts,vue} — 1 file [STARTED] eslint --fix [FAILED] eslint --fix [FAILED] [FAILED] eslint --fix [FAILED] [COMPLETED] Running tasks for staged files... [STARTED] Applying modifications from tasks... [SKIPPED] Skipped because of errors from tasks. [STARTED] Reverting to original state because of errors... [COMPLETED] Reverting to original state because of errors... [STARTED] Cleaning up temporary files... [COMPLETED] Cleaning up temporary files...✖ eslint --fix:C:\Users\31501\Desktop\a-a-a\src\main.js11:13 error gaga is not defined no-undef✖ 1 problem (1 error, 0 warnings)ELIFECYCLE  Command failed with exit code 1. husky - pre-commit hook exited with code 1 (error)把这个改成off 再次输入 git add . git commit -m 往历史代码中模拟一个错误代码 然后在别的地方在输入一个错误代码 然后再把off改回来,在进行一次校验,他只会对新的错误进行校验,之前的错误不会校验出来 5.目录调整 默认生成的目录结构不满足我们的开发需求,所以这里需要做一些自定义改动 主要是以下工作: 删除一些初始化的默认文件删改剩余代码内容新增调整我们需要的目录结构拷贝全局样式和图片,安装预处理器支持 安装sass预处理器pnpm add sass -D 删除文件 修改内容 src/router/index.js import { createRouter, createWebHistory } from vue-routerconst router createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [] })export default routersrc/App.vue script setup/scripttemplatedivrouter-view/router-view/div /templatestyle scoped/stylesrc/main.js import { createApp } from vue import { createPinia } from piniaimport App from ./App.vue import router from ./routerconst app createApp(App)app.use(createPinia()) app.use(router) app.mount(#app)新增utils,api将项目需要的全局样式 和 图片文件复制到 assets 文件夹中, 并将全局样式在main.js中引入 import /assets/main.scss安装 sass 依赖 pnpm add sass -D 6.vue-router4 路由代码解析 基础代码解析 import { createRouter, createWebHistory } from vue-router// createRouter 创建路由实例 new VueRouter() // 1. history模式: createWebHistory() http://xxx/user // 2. hash模式: createWebHashHistory() http://xxx/#/user// vite 的配置 import.meta.env.BASE_URL 是路由的基准地址默认是 ’/‘ // https://vitejs.dev/guide/build.html#public-base-path// 如果将来你部署的域名路径是http://xxx/my-path/user // vite.config.ts 添加配置 base: my-path路由这就会加上 my-path 前缀了const router createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [] })export default routerimport.meta.env.BASE_URL 是Vite 环境变量https://cn.vitejs.dev/guide/env-and-mode.html 就是地址前面的一格,如果是js,那所有的跳转页面前面都会有一个js 但是这个不能写死,所以可以在vite.config.js里面配 以前的写法 import VueRouter from vue-router // 初始化 vue-router3.x(Vue2) const router new VueRouter({mode: history, // 配置路由模式:标识地址栏切换的时候是没有#的router: [], }) export default routervue3中的路由写法 import { createRouter, createWebHistory } from ‘vue-router’ // 初始化 vue-router4.x(Vue3) const router createRouter({ history: createWebHistory(import.meta.env.BASE_URL), router: [] }) export default router 1. 创建路由实例由createRouter实现 2. 路由模式1.history模式使用createWebHistory2.hash模式使用 createWebHashHistory()3.参数是基础路径,默认/PS router/index.js import { createRouter, createWebHistory } from vue-router// createRouter 创建路由实例 // 配置 history 哦是 // 1.history模式 createWebHistory 地址栏不带 # // 2.hash模式 createWebHashHistory 地址栏带# const router createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [] })export default routerApp.vue script setup // 在 Vue3 CompositionAPI中 // 1. 获取路由对象 router useRouter // const router useRouter() // 2. 获取路由参数 route useRoute // const route useRoute() import { useRoute,useRouter } from vue-router const router useRouter() // 获取路由,一个大的路由信息对象 const route useRoute() // 路由参数 const goList () {router.push(/list)console.log(router, route) }/script7.引入 Element Plus 组件库 官方文档 https://element-plus.org/zh-CN/ 找到指南 → 安装(装包) → 快速开始 安装 $ pnpm add element-plus自动按需 安装插件 pnpm add -D unplugin-vue-components unplugin-auto-import然后把下列代码插入到你的 Vite 或 Webpack 的配置文件中 ... import AutoImport from unplugin-auto-import/vite import Components from unplugin-vue-components/vite import { ElementPlusResolver } from unplugin-vue-components/resolvers// https://vitejs.dev/config/ export default defineConfig({plugins: [...AutoImport({resolvers: [ElementPlusResolver()]}),Components({resolvers: [ElementPlusResolver()]})] }) 直接使用 templatedivel-button typeprimaryPrimary/el-buttonel-button typesuccessSuccess/el-buttonel-button typeinfoInfo/el-buttonel-button typewarningWarning/el-buttonel-button typedangerDanger/el-button.../div /template而且components下面的组件也可以直接用,当标签用 8.Pinia 构建仓库 和 持久化 官方文档https://prazdevs.github.io/pinia-plugin-persistedstate/zh/ 安装插件 pinia-plugin-persistedstate pnpm add pinia-plugin-persistedstate -D使用 main.js import persist from pinia-plugin-persistedstate ... app.use(createPinia().use(persist))配置 stores/user.js import { defineStore } from pinia import { ref } from vue// 用户模块 export const useUserStore defineStore(big-user,() {const token ref() // 定义 tokenconst setToken (t) (token.value t) // 设置 tokenreturn { token, setToken }},{persist: true // 持久化} ) 9.Pinia 仓库统一管理 pinia 独立维护 现在初始化代码在 main.js 中仓库代码在 stores 中代码分散职能不单一 优化由 stores 统一维护在 stores/index.js 中完成 pinia 初始化交付 main.js 使用 仓库 统一导出 现在使用一个仓库 import { useUserStore } from ./stores/user.js 不同仓库路径不一致 优化由 stores/index.js 统一导出导入路径统一 ./stores而且仓库维护在 stores/modules 中 目录如下 index.js import { createPinia } from pinia import persist from pinia-plugin-persistedstateconst pinia createPinia() pinia.use(persist)export default pinia// import { useUserStore } from ./modules/user // export { useUserStore }// import { useCountStore } from ./modules/counter // export { useCountStore } // export * from ./modules/user export * from ./modules/countercounter.js import { defineStore } from pinia import { ref } from vue// 数字计数器模块 export const useCountStore defineStore(big-count, () {const count ref(100)const add (n) {count.value n}return {count,add} })App.vue script setup // 在 Vue3 CompositionAPI中 // 1. 获取路由对象 router useRouter // const router useRouter() // 2. 获取路由参数 route useRoute // const route useRoute() // import { useRoute,useRouter } from vue-router import { useUserStore, useCountStore } from /stores // import { useCountStore } from /stores/modules/counter.js // const router useRouter() // 获取路由,一个大的路由信息对象 // const route useRoute() // 路由参数 // const goList () { // console.log(router, route) // }const userStore useUserStore() const countStore useCountStore() /scripttemplatedivwoshiAppp{{ userStore.token }}/pel-button clickuserStore.setToken(Bearer uiasfghdukashfk)登录/el-buttonel-button clickuserStore.removeToken()退出/el-buttonhr /{{ countStore.count }}el-button clickcountStore.add(2)加法/el-button/div /templatestyle scoped/style
http://www.zqtcl.cn/news/237553/

相关文章:

  • 东莞网站制作个性化清溪网站仿做
  • 简单展示网站模板天津建设网站哪家好
  • 建个人网站赚钱多吗福建省住房和城乡建设厅网站首页
  • 网站建设课程设计实训心得seo关键词优化方案
  • 逸阳网站建设的目标郑州建设电商网站
  • 有了网址怎么做网站上海网站推广服务
  • 惠州网站seo排名优化esc怎么做网站
  • 咨询公司网站设计网站建设技能
  • 上海湖南网站建设新学校网站建设成果
  • 网站开发有哪些竞赛建站行业新闻
  • 满足seo需求的网站大型网站常见问题
  • 做网站要求高吗珠宝网站建设
  • 网站建设方案 预算高端制作网站哪家专业
  • 响应式网站什么意思长春做个人网站做不了
  • 手机网站排名优化软件网站登陆页面怎么做
  • 辽宁网站建设价格杭江建设有限公司
  • 成立公司在什么网站网络推广推广培训
  • 承德网站制作公司哪家好公司网络组建方案模板
  • 用wordpress 建网站网站关键词怎么改
  • 怎么做网站做站点创建站怎么上传网站怎么办
  • 十堰网站建设专家html做的旅游网站
  • 网站项目上线流程网站改版需求说明
  • 网站建设制作公司xshell如何做网站
  • 义乌个人兼职做建设网站琼海做网站公司
  • 什么网站可以直接做word在柬埔寨做网站彩票推广
  • 深圳市宝安区住房和建设局网站校园网络方案设计
  • 株洲建设网站制作seo快速软件
  • 建站什么程序好wordpress返佣
  • 网站建设使用虚拟主机的优点与缺点马蹄室内设计论坛
  • 像wordpress一样的网站wordpress提示数据库出错