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

免费网站自助建站系统违法网站建设国外服务器

免费网站自助建站系统,违法网站建设国外服务器,长春火车站有几个,如何在网站做电子报先上个效果图#xff0c;代码可以直接拿~ 安装swiper和vue-awesome-swiper 因为项目用的是nuxt2#xff0c;所以考虑到swiper的兼容问题#xff0c;选择的是swiper: “^5.2.0” 首先是安装swiper和vue-awesome-swiper#xff0c;并指定版本 npm install s…先上个效果图代码可以直接拿~ 安装swiper和vue-awesome-swiper 因为项目用的是nuxt2所以考虑到swiper的兼容问题选择的是swiper: “^5.2.0” 首先是安装swiper和vue-awesome-swiper并指定版本 npm install swiper5.2.0 --savenpm install vue-awesome-swiper4.1.1 --save然后引入在nuxt.config.js中引入 css: [swiper/css/swiper.css ], plugins: [{ src: /plugins/vue-swiper, ssr: false } ],基本用法 在plugins下新建一个vue-swiper.js import Vue from vue import VueAwesomeSwiper from vue-awesome-swiper Vue.use(VueAwesomeSwiper)在components下新建一个VueSwiper.vue templatediv v-ifinitStatus v-swiper:mySwiperswiperOption classswiper mySwiper swiperBoxdiv classswiper-wrapperdiv classswiper-slide v-for(item, index) in list.value :keyindexdiv classprdiv classswiper-slide-imgbox uf uf-ac uf-jcimg :srcitem.imageUrl //divdiv classfont12 c8 txt-box{{ item.title }}/div/div/div/divdiv classswiper-button-prev/divdiv classswiper-button-next/div/div /template script export default {props: {list: {//banner数组type: Object,default: function () {return {}}},slidesPerView: {//一页显示几个type: Number,default: 1}},data() {return {initStatus: false,//初始化状态swiperOption: {},//swiper参数}},mounted() {let self this;this.$nextTick(() {this.swiperOption {loop: true,loopAdditionalSlides: 3,coverflowEffect: {rotate: 60, //侧转角度正值凹陷stretch: -80,//每个slide之间拉伸值正值紧贴depth: 100, //值越大为远景可负值modifier: 1, //depth和rotate和stretch的倍率shadows: false},centeredSlides: true,initialSlide: 1,slidesPerView: self.slidesPerView,//一页显示几个spaceBetween: 10,//间隔updateOnWindowResize: true,watchSlidesProgress: true,//noSwiping: true,//effect: coverflow, //设置Slide的切换效果默认为slide普通位移切换还可设置为fade淡入、cube方块、coverflow3d流、flip3d翻转、cards(卡片式)、creative创意性。freeMode: 1,autoplay: {//自动轮播//delay: 3000, //disableOnInteraction: false,//操作swiper后 自动轮播不会停止//},navigation: {nextEl: .swiper-button-next,prevEl: .swiper-button-prev,},}this.initStatus true //渲染swiper})}, } /script style langscss scoped .swiper {margin-left: auto;margin-right: auto;position: relative;box-sizing: border-box; } .swiper-wraper {width: 100%;height: 100%;z-index: 1;display: flex;box-sizing: content-box; } .swiper-slide {flex-shrink: 0;width: 100%;height: 100%; } .swiper-slide-imgbox{width: 315px;height: 302px;opacity: 1;background: rgba(255, 255, 255, 1);padding: 20px;box-sizing: border-box; } .pr{position: relative; } .txt-box{position: absolute;bottom: -40px;left: 0;right: 0;margin: 0 auto; } /style在plugins下引入 // 引入vue 及 组件 import Vue from vue import VueSwiper from /components/VueSwiper// 全局注册组件 Vue.component(VueSwiper, VueSwiper)然后是使用这个组件在pages下新建一个honor.vue templatediv classmain-containerPageHeader /!-- banner --div classbanner-boxdiv classfont48 weight700 c3资质与荣誉/divdiv classfont16 weight400 c7 op7 mt30Qualifications and Honors/div/divdiv classcontent-box v-for(honorItem, index) in honorTypes :keyindexdiv classfont36 pt100 mb40 vc v-ifhonorInfo[index] honorInfo[index].value honorInfo[index].value.length{{ honorItem.title }}/divdiv classreview-content v-ifhonorInfo[index] honorInfo[index].value honorInfo[index].value.lengthvue-swiper :listhonorInfo[index] :slidesPerView3/vue-swiper/div/divPageFooter //div /templatescript import { shareToWechat } from ../../utils/format; export default {name: Honor,data() {return {showType: honor,honorTypes: [],honors: [],honorInfo: []};},methods:{async findHonorTypeData() {let _params {order: sort}this.loading true;const res await this.$axios.$get(/certType, { params: _params });this.loading false;let _this thisif (res res.status 0) {this.honorTypes res.resultres.result.forEach((item, i) {_this.findHonorsData(item.title)})} else {this.$message.error(res.message);}},async findHonorsData(certType) {let _params {order: sort,certType: certType,pageNum: 1,pageSize: 30}this.loading true;const res await this.$axios.$get(/certList, { params: _params });this.loading false;let _this thisif (res res.status 0) {res.result.rows.forEach((item, i) {item.imageUrl /images${item.imageUrl}})let _obj {name: certType,value: res.result.rows}_this.honorInfo.push(_obj)} else {this.$message.error(res.message);}},},mounted () {this.findHonorTypeData()} }; /scriptstyle langscss scoped .content-box{background-color: rgba(239, 241, 244, 1);padding-bottom: 100px; } .review-content {width: 100%;height: 302px;position: relative;margin: 0 auto;.swiperBox {height: 360px;width: 100%;position: static;padding-top: 20px; /deep/ {.swiper-slide {text-align: center;font-size: 18px;background: #fff;width: 315px !important;height: 302px;/* Center slide text vertically */display: -webkit-box;display: -ms-flexbox;display: -webkit-flex;display: flex;-webkit-box-pack: center;-ms-flex-pack: center;-webkit-justify-content: center;justify-content: center;-webkit-box-align: center;-ms-flex-align: center;-webkit-align-items: center;align-items: center;transition-property: all;img {max-width: 295px;height: auto;max-height: 282px;border-radius: 2px;}.swiper-slide-shadow-left{background-image: none}.swiper-slide-shadow-right{background-image: none}}.swiper-slide-active {.mask {display: none;}}.swiper-button-prev,.swiper-button-next {position: absolute;width: 34px;height: 64px;line-height: 64px;border-radius: 6px;font-size:30px;color: #00A2FF;top: 50%;}.swiper-button-prev:after,.swiper-button-next:after {font-size: 30px;:hover{background-color: none;}}.swiper-button-prev {left: 0px;}.swiper-button-next {right: 0px;}.swiper-button-prev:hover,.swiper-button-next:hover {background: rgba(209, 209, 209, 0.5);color: rgba(255, 255, 255, 0.5);}}} } .banner-box {height: 370px;opacity: 1;padding: 172px 120px 0 120px;box-sizing: border-box;background: url(/images/productImages/honor.png) right 120px bottom 20px / 320px auto no-repeat,linear-gradient(90deg, rgba(137, 247, 254, 1) 0%, rgba(84, 156, 252, 1) 100%);; } .honor-box {max-width: 990px;padding-bottom: 82px;margin: 0 auto; .honor-card {width: 300px;margin: 0 15px 48px;box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.16);border-radius: 4px;background-clip: content-box;background-color: rgba(255, 255, 255, 1);background-position: center center;background-size: 100% auto;background-repeat: no-repeat;.large {padding: 32px;}.small {padding: 19px 15px;}} } media screen and (max-width: 768px) {.banner-box {height: 260px;background-position: center top 100px, left top;background-size: auto 80px, auto 100%; .banner-content {top: 260px;width: 100%;}}.honor-box {justify-content: center;padding: 0 30px 20px; .honor-card {width: 300px;margin: 0 15px 20px;}} } /style出现空白页的bug 使用了swiper的coverflowEffect效果设置了同时显示3个同时开启了loop模式。 当切换到倒数第二张时没有新的slider生成导致最后一张的右边是空白的只有切换到最后一张时才会再在后面复制新的slider怎么让它在显示倒数第二张时就生成新的slider 最后发现slidesPerView设置为auto就正常了 然后调整coverflowEffect里的stretch和depth来弄就没问题了 VueSwiper.vue templatediv v-ifinitStatus v-swiper:mySwiperswiperOption classswiper mySwiper swiperBoxdiv classswiper-wrapperdiv classswiper-slide v-for(item, index) in list.value :keyindexdiv classprdiv classswiper-slide-imgbox uf uf-ac uf-jcimg :srcitem.imageUrl //divdiv classfont12 c8 txt-box{{ item.title }}/div/div/div/divdiv classswiper-button-prev/divdiv classswiper-button-next/div/div /template script export default {props: {list: {//banner数组type: Object,default: function () {return {}}}},data() {return {initStatus: false,//初始化状态swiperOption: {},//swiper参数}},mounted() {let self this;this.$nextTick(() {this.swiperOption {loop: true,loopAdditionalSlides: 3,coverflowEffect: {rotate: 50, //侧转角度正值凹陷stretch: -110,//每个slide之间拉伸值正值紧贴depth: 100, //值越大为远景可负值modifier: 1, //depth和rotate和stretch的倍率shadows: false},centeredSlides: true,initialSlide: 1,slidesPerView: auto,//一页显示几个spaceBetween: 10,//间隔updateOnWindowResize: true,watchSlidesProgress: true,//noSwiping: true,//effect: coverflow, //设置Slide的切换效果默认为slide普通位移切换还可设置为fade淡入、cube方块、coverflow3d流、flip3d翻转、cards(卡片式)、creative创意性。freeMode: 1,autoplay: {//自动轮播//delay: 3000, //disableOnInteraction: false,//操作swiper后 自动轮播不会停止//},navigation: {nextEl: .swiper-button-next,prevEl: .swiper-button-prev,},}this.initStatus true //渲染swiper})}, } /script style langscss scoped .swiper {margin-left: auto;margin-right: auto;position: relative;box-sizing: border-box; } .swiper-wraper {width: 100%;height: 100%;z-index: 1;display: flex;box-sizing: content-box; } .swiper-slide {flex-shrink: 0;width: 100%;height: 100%; } .swiper-slide-imgbox{width: 315px;height: 302px;opacity: 1;background: rgba(255, 255, 255, 1);padding: 20px;box-sizing: border-box; } .pr{position: relative; } .txt-box{position: absolute;bottom: -40px;left: 0;right: 0;margin: 0 auto; } /style
http://www.pierceye.com/news/318698/

相关文章:

  • 用vs2013做网站公司网站突然404
  • 东莞建站模板搭建广东商城网站建设
  • crm网站下载网站建设网址网站制作
  • 网站开发怎么入驻京东花店网站开发参考文献
  • 郑州专业网站推广优化公司技术支持 东莞网站建设
  • 苏州做网站的公司哪家最好网站企业
  • 厦门做网站seo网络营销就是什么
  • 哪个网站可以学做蛋糕网络软件系统
  • 网站制作的核心要点是什么找人做网站服务器不是自己的怎么办
  • 自己做国际网站福建省文明建设办公室网站
  • 天津专业做网站的公司私人免费网站怎么下载
  • 深圳网站设计灵点网络口碑好广州海珠建网站
  • 网站开启gzip压缩西安的推广公司
  • 深圳彩票网站建设企业邮箱免费版开通
  • 佛山网站建设网络推广wordpress文章加音频
  • 设计师新手接单网站怎么把自己做的网站
  • 动漫制作专业在国企河北网络营销推广seo
  • 潜江网站建设兼职万网人网站备案流程
  • 物流官网网站今天新闻联播
  • 郑州网站开发的公司三亚今天最新通知
  • 足球直播网站怎么做东莞市公司网站建设平台
  • 建设网站需要了解什么校园网站建设和管理工作制度
  • 网站商务通弹出窗口图片更换设置移动端cpu
  • 成都画册设计的公司海外seo托管
  • 中国早期互联网公司河南seo网站开发
  • wordpress添加短代码优化营商环境的金句
  • 网站访问统计js代码wordpress后台登陆不进去
  • dede 网站版权信息互联网平面设计
  • 可以做试卷的网站看书网站排名
  • seo网站关键词优化排名鄂州市网站