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

移动端网站开发前端模板/淄博新闻头条最新消息

移动端网站开发前端模板,淄博新闻头条最新消息,九江开发区建设规划局网站,个人网站内容如何填写下面我就为大家分享一篇vue实现图片滚动的示例代码(类似走马灯效果),具有很好的参考价值,希望对大家有所帮助。上次写了一个简单的图片轮播,这个相当于在上面的一些改进。这个组件除了可以进行图片滚动外,也可以嵌入任何内容的标签…

下面我就为大家分享一篇vue实现图片滚动的示例代码(类似走马灯效果),具有很好的参考价值,希望对大家有所帮助。

上次写了一个简单的图片轮播,这个相当于在上面的一些改进。这个组件除了可以进行图片滚动外,也可以嵌入任何内容的标签进行滚动,里面用了slot进行封装。

父:

-----使用子组件传过来的值,封装slot

{{props.item.title}}

import ErCarouselIndex from './components/carouselIndex/src/carouselIndex.vue'

export default {

name: 'app',

data() {

}

},

components: {

ErCarouselIndex//一定要进行组件声明,不然不能引用子组件

}

}

子组件:

style="max-height:50%;">

export default

{

name: "ErCarouselIndex",

data(){

return {

imgList: [],//请求接口数据

imgLisShow: [],//图片滚动数据,包括左中右三种

timer: null,//自动循环滚动时的间隔时间

timeout:null,//长按时的图片滚动间隔时间

index:0,//图片索引

translateXnum:0,//图片滚动时的偏移量

translateX:"",//生成图片偏移时的表达式

imgWidth:"",//图片所占宽度

timeDown:"",//鼠标刚按下时的时间

timeup:"",//鼠标松开时的时间

clickSpace:"",//鼠标按下松开的时间间隙

transFlag:true,//是否匀速滚动,

transitionTime:"",

indexCircle:0//小圆圈滚动索引

}

},

props:{

duration:0,//图片延时滚动

typeNumber:0, //每次滚动几张

timeSpace:0, //图片滚动时间间隔

url:String,//请求接口地址

pageNumber:0,//当前页面显示几张图片

isOrNotButton:true,//是否显示左右按钮

isOrNotCircle:true,//是否显示小圆圈

imgHeight:""//图片滚动显示高度

},

watch:{

index:{

handler(){

var _this=this;

if(Math.abs(this.index)==this.imgList.length){

this.indexCircle=0;

setTimeout(function(){

_this.reset();

},_this.duration*1000*0.98);

}else{

this.indexCircle=this.index;

}

this.calcXnum();

}

},

translateXnum:{

handler(){

this.translateX="translateX("+this.translateXnum+"%)";

}

}

},

methods:{

//页面初始化复赋值

imgView:function() {

var _this = this;

_this.$http.get(_this.url).then(function (res) {

_this.imgList = res.data.imgList;

for(var i=0;i<3;i++){

_this.imgList.forEach(function (item, index) {

_this.imgLisShow.push(item);

});

}

_this.reset();

_this.slideAuto();

_this.imgWidth=(100/_this.pageNumber)-1;

_this.transitionTime="all "+_this.duration*0.98+"s linear";

console.log(_this.transitionTime);

});

},

//图片滚动方法(长按)

imgMove:function(direct){

var _this = this;

_this.timeDown=new Date();//记录按下的时间

_this.timeout = setInterval(function() {

if(direct=="mouseLeft") {

_this.leftMove();

}else{

_this.rightMove();

}

},300);

},

//鼠标送开时执行的方法

cancelMove:function(direct){

var _this = this;

_this.clearAuto();

this.timeup=new Date();//记录松开的时间

this.clickSpace=this.timeup.getTime() - this.timeDown.getTime();

//时间间隔小于500毫秒为点击,反之为长按

if(this.clickSpace<500){

for(var i=0;i<_this.typenumber>

if(direct=="left"){

_this.leftMove();

}else{

_this.rightMove();

}

}

}

if (this.timeout) {

clearInterval(this.timeout);

this.timeout = null;

}

},

//向左移动

leftMove:function(){

this.index--;

this.transFlag=true;

},

//向右移动

rightMove:function(){

this.transFlag=true;

this.index++;

},

slideAuto:function () {

var _this = this;

_this.timer = setTimeout(function () {

if(Math.abs(_this.index)!==_this.imgList.length){

_this.rightMove();

_this.slideAuto();

}

}, _this.timeSpace * 1000);

},

clearAuto:function () {

console.log("停止");

if (this.timer) {

clearInterval(this.timer);

this.timer = null;

}

},

//重置

reset:function(){

this.index=0;

this.transFlag=false;

this.calcXnum();

},

calcXnum:function(){

var _this=this;

this.translateXnum=-(this.index+this.imgList.length)*(100/this.pageNumber);

},

//点击圆圈跳转图片

circleClick:function(dex){

this.index=dex;

this.clearAuto();

}

},

mounted()

{

this.$nextTick(function () {

this.imgView();

});

}

}

这个组件相对来说功能比较完整,用户可以通过传参来控制当前页面需要显示几张图片,图片滚动时间间隔,是否显示左右点击按钮等等,详细参数可以查看props,里面都有注释。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

http://www.jmfq.cn/news/5156623.html

相关文章:

  • 建筑模板915 1830价格/企业seo顾问公司
  • 做网站推广还是B2B推广好/运营推广计划怎么写
  • 女与男爱做电影网站免费/营销的四种方式
  • 一流的中小型网站建设/谷歌seo顾问
  • 个人备案 做政府网站/淘宝关键词搜索量查询工具
  • 深圳网站制作开发排名/互联网推广方案
  • 东莞做微网站建设/郑州seo优化推广
  • 博客转wordpress/如何优化关键词的方法
  • 爱搜索中级网站建设/做网站的公司有哪些
  • 南京专业建站/推广网站的公司
  • 网站建设 参照 标准规范/什么是网络销售
  • 乌鲁木齐市做平台网站/百度推广咨询
  • 重庆网站建设 优化/怎么引流到微信呢
  • 泉州哪家网站建设公司好/百度百度一下你就知道
  • 新加坡网站开发公司/微信营销软件排行榜
  • 北京网站建设怎么样天/互动营销的方式有哪些
  • 制作网站的网页/网站快速优化排名官网
  • 嘉兴网站建设定制网站/站长工具关键词排名怎么查
  • 购买网站广告位/软件培训机构有哪些?哪个比较好
  • 制作一个简单的php网站/百度联盟怎么加入赚钱
  • 网站手机端做排名靠前/网络营销推广系统
  • 建设银行手机官方网站下载安装/企业宣传推广怎么做
  • 微信网站界面设计/手机端竞价恶意点击
  • 做直播网站需要哪些技术/企业网站建设流程
  • 在ps中网站界面应做多大/营销活动方案
  • 网站栏目模板如何选择/网站为什么要做seo
  • 泰和县网站免费建站/关键词查询工具免费
  • 硬件定制/九幺seo工具
  • 网站美工外包公司/短视频运营是做什么的
  • 深圳网站建设响应式/成人技能培训