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

江苏省建设集团有限公司网站驻马店seo

江苏省建设集团有限公司网站,驻马店seo,wordpress仅显示标题,石家庄24号解封通知目录 一、Mock ( 1 ) 讲述 ( 2 ) 作用 二、引用 三、主页搭建 学习后带来的收获 一、Mock ( 1 ) 讲述 Mock.js是一个用于前端开发中模拟数据的库。它可以帮助开发人员在前端开发过程中模拟接口返回的数据#xff0c;从而实现前后端分离开发。Mock.js提供了一套简单易…目录 一、Mock ( 1 )  讲述 ( 2 )  作用 二、引用 三、主页搭建 学习后带来的收获 一、Mock ( 1 )  讲述 Mock.js是一个用于前端开发中模拟数据的库。它可以帮助开发人员在前端开发过程中模拟接口返回的数据从而实现前后端分离开发。Mock.js提供了一套简单易用的语法可以生成随机数据拦截Ajax请求模拟接口返回数据等功能。 数据类型丰富支持生成随机的文本、数字、布尔值、日期、邮箱、链接、图片、颜色等。 拦截Ajax请求不需要修改既有代码就可以拦截Ajax请求返回模拟的响应数据。 更多内容可查看Mockjs官方 Mock.js的主要特点包括 1. 生成随机数据Mock.js提供了丰富的数据模板可以根据模板生成符合规则的随机数据。例如可以生成随机的姓名、地址、手机号码等。 2. 拦截Ajax请求Mock.js可以拦截Ajax请求并根据预先定义好的数据模板返回模拟数据。这样开发人员可以在前端开发过程中独立于后端进行开发和调试。 3. 模拟接口返回数据Mock.js可以模拟接口返回数据开发人员可以根据接口文档定义接口返回的数据结构和类型然后使用Mock.js生成符合要求的模拟数据。 4. 支持插件扩展Mock.js提供了插件机制可以方便地扩展其功能。开发人员可以根据自己的需求编写插件实现更复杂的数据模拟和拦截功能。 使用Mock.js可以帮助开发人员在前端开发过程中快速搭建模拟数据提高开发效率减少对后端接口的依赖。同时Mock.js还可以帮助开发人员进行接口联调和单元测试提高代码质量。 ( 2 )  作用 Mock的主要作用是在前端开发过程中模拟数据从而实现前后端分离开发。 具体来说Mock的作用包括 1. 独立开发Mock可以帮助前端开发人员在后端接口未完成或不可用的情况下独立进行前端开发。通过使用Mock.js生成模拟数据前端开发人员可以在没有后端接口的情况下完成页面的开发和调试。 2. 接口联调Mock可以用于前后端接口联调。在后端接口未完成或不可用的情况下前端开发人员可以使用Mock.js模拟后端接口返回的数据进行接口联调和测试。 3. 单元测试Mock可以用于前端代码的单元测试。通过使用Mock.js生成模拟数据可以模拟不同的测试场景对前端代码进行单元测试提高代码质量和稳定性。 4. 数据展示Mock可以用于前端页面的数据展示。在开发过程中可以使用Mock.js生成模拟数据填充页面以便进行样式和布局的调试。 总的来说Mock的作用是帮助前端开发人员在前后端分离的开发模式下独立开发、接口联调、单元测试和数据展示提高开发效率和代码质量。 二、引用 以下的操作及代码都是基于博客中 : 使用ElementUI完成登入注册的跨域请求  使用CMD命令窗口并跳转到指定工作目录下创建项目 输入以下命令来安装Mock: npm i mockjs -D 如图 :  在项目的 package.json 文件中找到如图说明安装下载完成 为了只在开发环境使用mock而打包到生产环境时自动不使用mock我们可以在config目录中的dev.env.js和prod.env.js做一个配置如下 dev.env.js   module.exports merge(prodEnv, {NODE_ENV: development,MOCK: true }) prod.env.js: module.exports {NODE_ENV: production,MOCK: false } 并且在项目中的 main.js 中配置 //开发环境下才会引入mockjs process.env.MOCK require(/mock) 创建src/mock/json目录定义登录测试数据文件login-mock.js // const loginInfo { // code: -1, // message: 密码错误 // }//使用mockjs的模板生成随机数据 const loginInfo {code|-1-0: 0,message|3-10: msg } export default loginInfo;在src/mock目录下创建index.js定义拦截路由配置 import Mock from mockjs //引入mockjsnpm已安装 import action from /api/action //引入请求地址//全局设置设置所有ajax请求的超时时间模拟网络传输耗时 Mock.setup({// timeout: 400 //延时400s请求到数据timeout: 200 - 400 //延时200-400s请求到数据 })//引登陆的测试数据并添加至mockjs import loginInfo from /mock/json/login-mock.js let s1 action.getFullPath(SYSTEM_USER_DOLOGIN) Mock.mock(s1, post, loginInfo) // Mock.mock(s1, /post|get/i, loginInfo)编辑我们已有的 Login.vue 的组件 templatediv classlogin-wrapel-form classlogin-containerh1 classtitle用户登录/h1el-form-item labelel-input typetext v-modelusername placeholder登录账号 autocompleteoff/el-input/el-form-itemel-form-item labelel-input typepassword v-modelpassword placeholder登录密码 autocompleteoff/el-input/el-form-itemel-form-itemel-button typeprimary stylewidth:100%; clickdoSubmit()提交/el-button/el-form-itemel-row styletext-align: center;margin-top:-10pxel-link typeprimary忘记密码/el-linkel-link typeprimary clickRegister()用户注册/el-link/el-row/el-form/div /templatescriptimport axios from axios //用于GET请求import qs from qs //用于post请求export default {name: Login,data() {return {username: ,password: ,msg: 嗨嗨嗨}},methods: {Register() {this.$router.push(/Register);},doSubmit() {let params {username: this.username,password: this.password};console.log(params);//定义后端都请求地址var url this.axios.urls.SYSTEM_USER_DOLOGIN;//注意数据是保存到json对象的params属性//以下是GET请求//进行请求携带数据进行登入访问// axios.get(url, {// //携带的参数(数据)// params: params,// }).then(r {// //如果携带的参数数据跟后端数据对应正确说明登入成功提示// if (r.data.success) {// this.$message({// showClose: true,// message: r.data.msg,// type: success// });// } else {// //如果携带的参数数据跟后端数据对应错误说明登入失败提示// this.$message.error(r.data.msg);// }// console.log(r);// }).catch(e {// console.log(e);// });//以下是post请求及整合资源//通过qs中的stringify方法进行格式转换//注意数据是保存到json对象的params属性this.axios.post(url, params).then(r {console.log(r);// // 如果携带的参数数据跟后端数据对应正确说明登入成功提示if (r.data.code0) {this.$message({showClose: true,message: r.data.message,type: success});this.$router.push(/AppMain);} else {//如果携带的参数数据跟后端数据对应错误说明登入失败提示this.$message.error(r.data.message);}// this.$message({// message: r.data.message,// type : r.data.code 0 ? error : success// });// this.$router.push(/AppMain);}).catch(e {console.log(e);});}}} /scriptstyle scoped.login-wrap {box-sizing: border-box;width: 100%;height: 100%;padding-top: 10%;background-image: url();/* background-color: #112346; */background-repeat: no-repeat;background-position: center right;background-size: 100%;}.login-container {border-radius: 10px;margin: 0px auto;width: 350px;padding: 30px 35px 15px 35px;background: #fff;border: 1px solid #eaeaea;text-align: left;box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);}.title {margin: 0px auto 40px auto;text-align: center;color: #505458;} /style然后在项目路径下面输入以下命令开启项目。 开启命令 :  npm run pev 效果如图   你可以使用Mock.js来生成随机id值。Mock.js是一个用于生成随机数据的库可以模拟接口返回的数据。以下是使用Mock.js生成随机id值的示例代码 const Mock require(mockjs);const data Mock.mock({id: guid });console.log(data.id); 在上述示例中我们使用guid来生成一个随机的id值。你可以根据需要将其应用到你的代码中。 你可以参考以下资源来了解更多关于Mock.js的使用 1. [mockjs 基本使用-按指定规则生成随机测试数据] 2. [初识MockJS生成随机数据 - 稀土掘金] 3. [mockjs-生成随机数据_mock.js配置随机车牌] 希望对你有帮助 字符串String let obj1 Mock.mock({star|1-5:★,//生成指定范围长度的字符串info:静态的字符串,//静态字符串name:cname//使用规定占位符cname随机生成中国人的名字 }) obj1对象包含了三个属性star、info和name。 star属性使用star|1-5:★规则生成一个长度为1到5的字符串内容为★。info属性是一个静态的字符串值为静态的字符串。name属性使用cname规则随机生成一个中国人的名字。 使用ES6的对象字面量语法 const obj1 {star: ★.repeat(Math.floor(Math.random() * 5) 1),info: 静态的字符串,name: Mock.mock(cname) };console.log(obj1);使用普通的对象赋值语法 const obj1 {}; obj1.star ★.repeat(Math.floor(Math.random() * 5) 1); obj1.info 静态的字符串; obj1.name Mock.mock(cname);console.log(obj1);正则表达式规则 let obj7 Mock.mock({user:{name:cname,},tel:/1[0-9]{10}/,//正则表达式可以使用插件email:/^[A-Za-z0-9\u4e00-\u9fa5][a-zA-Z0-9_-](\.[a-zA-Z0-9_-])$/,//函数表达式info:function(){//注意这里的this指向是数据模板对象所以可以在函数表达式里使用this来获取已有值return 我的手机号码是:${this.tel},我的邮箱是:${this.email},我的身份证号码是:${this.cardId}},// (8)路径规则中 表示启动关键字(注意前面不能有除了空格的任何其他字符)// / 表示在模板数据中的层级关系上下级message:我的名字是: /user/name ,我的手机号码是: /tel,我的邮箱是: /email,我的身份证号码是: /cardId }) console.log(obj7); Mock.mock()函数接受一个对象作为参数该对象定义了模拟数据的结构和规则。 user属性是一个对象其中的name属性使用cname作为占位符表示生成一个中文名字。 tel属性是一个正则表达式用于生成符合规则的手机号码。 email属性也是一个正则表达式用于生成符合规则的邮箱地址。 info属性是一个函数用于返回一个字符串其中包含了tel、email和cardId的值。注意函数中的this指向的是数据模板对象所以可以使用this来获取已有的属性值。 message属性是一个字符串其中包含了占位符/user/name、/tel、/email和/cardId分别表示引用user对象的name属性、tel属性、email属性和cardId属性的值。 最后通过console.log()打印出生成的模拟数据对象obj7。 总结这段代码使用Mock.js库生成了一个包含模拟数据的对象obj7其中的属性使用了不同的规则来生成对应的值。info函数和message字符串中使用了占位符来引用其他属性的值。 三、主页搭建 在项目的 components 文件中创建以下三个组件 AppMain.vue templateel-container classmain-containerel-aside v-bind:classasideClassLeftNav/LeftNav/el-asideel-containerel-header classmain-headerTopNav/TopNav/el-headerel-main classmain-centerMain/el-main/el-container/el-container /templatescript// 导入组件import TopNav from /components/TopNav.vueimport LeftNav from /components/LeftNav.vue// 导出模块export default {components: {TopNav,LeftNav},data() {return {asideClass: main-aside}},created() {this.$root.bus.$on(shrink, t {this.asideClass t ? main-aside-collapsed : main-aside;});}}; /script style scoped.main-container {height: 100%;width: 100%;box-sizing: border-box;}.main-aside-collapsed {/* 在CSS中通过对某一样式声明! important 可以更改默认的CSS样式优先级规则使该条样式属性声明具有最高优先级 */width: 64px !important;height: 100%;background-color: #334157;margin: 0px;}.main-aside {width: 240px !important;height: 100%;background-color: #334157;margin: 0px;}.main-header,.main-center {padding: 0px;border-left: 2px solid #333;} /styleLeftNav.vue templateel-menu default-active2 classel-menu-vertical-demo background-color#334157text-color#fff active-text-color#ffd04b :collapsecollapsed !-- el-menu default-active2 :collapsecollapsed collapse-transition router :default-active$route.path unique-opened classel-menu-vertical-demo background-color#334157 text-color#fff active-text-color#ffd04b --div classlogoboximg classlogoimg src../assets/img/logo.png alt/divel-submenu index1template slottitlei classel-icon-location/ispan导航一/span/templateel-menu-item-grouptemplate slottitle分组一/templateel-menu-item index1-1选项1/el-menu-itemel-menu-item index1-2选项2/el-menu-item/el-menu-item-groupel-menu-item-group title分组2el-menu-item index1-3选项3/el-menu-item/el-menu-item-groupel-submenu index1-4template slottitle选项4/templateel-menu-item index1-4-1选项1/el-menu-item/el-submenu/el-submenuel-menu-item index2i classel-icon-menu/ispan slottitle导航二/span/el-menu-itemel-menu-item index3 disabledi classel-icon-document/ispan slottitle导航三/span/el-menu-itemel-menu-item index4i classel-icon-setting/ispan slottitle导航四/span/el-menu-item/el-menu /template scriptexport default {data(){return{collapsed:false}},created(){this.$root.bus.$on(shrink,t{this.collapsed t;});}} /script style.el-menu-vertical-demo:not(.el-menu--collapse) {width: 240px;min-height: 400px;}.el-menu-vertical-demo:not(.el-menu--collapse) {border: none;text-align: left;}.el-menu-item-group__title {padding: 0px;}.el-menu-bg {background-color: #1f2d3d !important;}.el-menu {border: none;}.logobox {height: 40px;line-height: 40px;color: #9d9d9d;font-size: 20px;text-align: center;padding: 20px 0px;}.logoimg {height: 40px;} /styleTopNav.vue template!-- el-menu :default-activeactiveIndex2 classel-menu-demo modehorizontal selecthandleSelect background-color#545c64text-color#fff active-text-color#ffd04bel-menu-item index1处理中心/el-menu-itemel-submenu index2template slottitle我的工作台/templateel-menu-item index2-1选项1/el-menu-itemel-menu-item index2-2选项2/el-menu-itemel-menu-item index2-3选项3/el-menu-itemel-submenu index2-4template slottitle选项4/templateel-menu-item index2-4-1选项1/el-menu-itemel-menu-item index2-4-2选项2/el-menu-itemel-menu-item index2-4-3选项3/el-menu-item/el-submenu/el-submenuel-menu-item index3 disabled消息中心/el-menu-itemel-menu-item index4a hrefhttps://www.ele.me target_blank订单管理/a/el-menu-item/el-menu --el-menu classel-menu-demo modehorizontal background-color#334157 text-color#fff active-text-color#fffel-button classbuttonimgimg classshowimg :srccollapsed?imgshow:imgsq clickdoToggle()/el-buttonel-submenu index2 classsubmenutemplate slottitle超级管理员/templateel-menu-item index2-1设置/el-menu-itemel-menu-item index2-2个人中心/el-menu-itemel-menu-item clickexit() index2-3退出/el-menu-item/el-submenu/el-menu /templatescriptexport default {data() {return {collapsed: false,imgshow: require(/assets/img/show.png),imgsq: require(/assets/img/sq.png)}},methods: {doToggle() {this.collapsed !this.collapsed;//将是否折叠的变量放入总线,用于监听左组件的收缩this.$root.bus.$emit(shrink, this.collapsed);},exit() {this.$router.push(/);}}} /scriptstyle scoped.el-menu-vertical-demo:not(.el-menu--collapse) {border: none;}.submenu {float: right;}.buttonimg {height: 60px;background-color: transparent;border: none;}.showimg {width: 26px;height: 26px;position: absolute;top: 17px;left: 17px;}.showimg:active {border: none;} /style 在下面中的src文件中的router文件的index.js文件进行配置 import Vue from vue import Router from vue-router import HelloWorld from /components/HelloWorld import AppMain from /components/AppMain import TopNav from /components/TopNav import LeftNav from /components/LeftNav import Home from /views/Home import About from /views/About import AboutMe from /views/AboutMe import AboutMeaning from /views/AboutMeaning import Login from /views/Login import Register from /views/Register Vue.use(Router)export default new Router({routes: [{path: /,name: Login,component: Login},{path: /Register,name: Register,component: Register},{path: /AppMain,name: AppMain,component: AppMain,children: [{path: /TopNav,name: TopNav,component: TopNav}, {path: /LeftNav,name: LeftNav,component: LeftNav}]}// {// path: /,// name: Home,// component: Home// },// {// path: /Home,// name: Home,// component: Home// },// {// path: /About,// name: About,// component: About,// children:[{// path: /,// name: AboutMe,// component: AboutMe// },{// path: /AboutMe,// name: AboutMe,// component: AboutMe// },{// path: /AboutMeaning,// name: AboutMeaning,// component: AboutMeaning// }]// }] })效果展示 :  学习后带来的收获 学会使用ElementUI结合Mock.js进行项目开发可以带来以下收获 1. 快速构建UI界面ElementUI是一个基于Vue.js的UI组件库提供了丰富的组件和样式可以帮助我们快速构建美观的UI界面减少开发时间和工作量 。 2. 模拟数据Mock.js是一个用于生成模拟数据的库可以帮助我们在开发过程中模拟接口返回的数据从而不依赖于后端接口的开发进展提高开发效率。 3. 前后端分离开发使用Mock.js可以模拟后端接口返回的数据使前端开发人员可以独立进行开发不需要等待后端接口的实现和联调加快项目开发进度。 4. 接口调试和测试使用Mock.js可以方便地模拟各种场景下的数据返回用于接口的调试和测试从而提高项目的稳定性和质量。 5. 提高代码质量使用ElementUI可以规范化和统一前端开发的样式和组件使用提高代码的可读性和可维护性而使用Mock.js可以减少对真实接口的依赖降低代码的耦合度使代码更加可测试和可扩展。 总之学会使用ElementUI结合Mock.js进行项目开发可以提高开发效率、加快项目进度、提高代码质量并且使前后端开发更加独立和高效。[连接了解]
http://www.zqtcl.cn/news/754346/

相关文章:

  • 晓风彩票网站建设软件微信上发的链接网站怎么做的
  • 关键词有哪几种台州优秀关键词优化
  • 盐田区住房和建设局网站软件开发文档怎么编写
  • 网站响应式建设seo排名优化怎样
  • 山东 网站备案德清县建设局网站
  • 中英语双语网站咋做提供网站建设设计外包
  • 云网站功能江门网站seo关键词排名优化
  • 潍坊网站建设外贸制作html网站
  • 网站友情链接怎么添加定制酒营销方案
  • 目前最流行网站开发软件泰州市建设工程招标网
  • 福州网站优化me域名网站
  • 网站 案例互联网外包公司值得去吗
  • 做医疗护具网站浙江立鹏建设有限公司网站
  • 织梦制作手机网站c 网站开发需要学什么软件
  • 罗湖网站制作阿里巴巴开店网站怎么做
  • 深圳住房和建设局网站 招标怎样建设自己的视频网站
  • 网站建设的目的模板茶网站建设需要多少钱
  • 珠海市城乡住房建设局网站网站外链
  • 福田做网站需要多少钱做淘宝客网站性质
  • html网站怎么进入后台网站主题怎么写
  • wordpress怎么ftp建站高端网站建设域名注册
  • 我用织梦5.7做个网站应该把淘宝客店铺链接放到哪聊天软件开发需要多少钱
  • 站长工具爱站竞价单页网站制作
  • 网站分类目录大全购物网站大全棉鞋
  • 网站镜像做排名建立外贸英文网站应该怎么做
  • 上海做网站就用乐云seo手机网站cms 下载
  • 做网站需要固定ip么灵犀科技网站建设
  • 深圳高端做网站建设网站备案与不备案区别
  • 家居企业网站建设公司苏州高新区建设局网站管网
  • 体育门户网站模板seo网络推广有哪些