Vue를 사용하여 원활한 스크롤 구성 요소를 구현하는 방법
이 글은 주로 vue의 심리스 스크롤 컴포넌트인 vue-seamless-scroll의 사용법을 설명합니다. 필요하신 분들은 참고하시면 됩니다.
Installation
NPM
npm install vue-seamless-scroll --save
Usage
ES6
다음 es6 사용에는 웹팩 환경 컴파일이 필요합니다.
<template> <p id="app"> <p class="fixed top-0 w-100 z-1 flex-none flex flex-row items-center pv3 ph4 bg-blue white"> <p class="flex-none"><a href="https://github.com/chenxuan0000/vue-seamless-scroll" rel="external nofollow" rel="external nofollow" rel="noopener" target="_blank" title="View on Github"> <svg xmlns="http://www.w3.org/2000/svg" fill="white" width="32" height="32" viewBox="0 0 16 16"> <path d="M8 .198c-4.418 0-8 3.582-8 8 0 3.535 2.292 6.533 5.47 7.59.4.075.548-.173.548-.384 0-.19-.008-.82-.01-1.49-2.227.485-2.696-.943-2.696-.943-.364-.924-.888-1.17-.888-1.17-.726-.497.055-.486.055-.486.802.056 1.225.824 1.225.824.714 1.223 1.872.87 2.328.665.072-.517.28-.87.508-1.07-1.776-.202-3.644-.888-3.644-3.954 0-.874.313-1.588.824-2.148-.083-.202-.357-1.015.077-2.117 0 0 .672-.215 2.2.82.64-.177 1.323-.266 2.003-.27.68.004 1.365.093 2.004.27 1.527-1.035 2.198-.82 2.198-.82.435 1.102.162 1.916.08 2.117.512.56.822 1.274.822 2.147 0 3.072-1.872 3.748-3.653 3.946.288.248.544.735.544 1.48 0 1.07-.01 1.933-.01 2.196 0 .213.145.462.55.384 3.178-1.06 5.467-4.057 5.467-7.59 0-4.418-3.58-8-8-8z"></path> </svg> </a> </p> <p class="flex-none" style="margin-left: 10px;"><a href="https://github.com/chenxuan0000/vue-seamless-scroll" rel="external nofollow" rel="external nofollow" class="white no-underline underline-hover">vue-seamless-scroll</a></p> </p> <p class="pt5 f2" style="text-align: center;">无缝滚动demo</p> <p class="flex wd800"> <p class="options" style="color:#357edd;"> <p><b>demo1</b> 向上无缝滚动,hover可停止</p> var option = {<br/> step: 0.5,<br/> limitMoveNum: 5<br/> } </p> <my-class :data="listData" :class-option="classOption" @copy-data="listData = listData.concat(listData)" class="warp"> <ul class="item"> <li v-for="item in listData"><span class="title" v-text="item.title"></span><span class="date" v-text="item.date"></span> </li> </ul> </my-class> </p> <p class="flex wd800"> <p class="options" style="color:#357edd;"> <p><b>demo2</b> limitMoveNum过大不滚动 开启了openWatch</p> <p>3s后data增加到9条</p> var option = {<br/> limitMoveNum: 7<br/> } </p> <my-class :data="listData1" :class-option="classOption1" @copy-data="listData1 = listData1.concat(listData1)" class="warp"> <ul class="item"> <li v-for="item in listData1"><span class="title" v-text="item.title"></span><span class="date" v-text="item.date"></span></li> </ul> </my-class> </p> <p class="flex wd800"> <p class="options" style="color:#357edd;"> <p><b>demo3</b> limitMoveNum过大不滚动 关闭了openWatch</p> <p>3s后data增加到9条</p> var option = {<br/> limitMoveNum: 7<br/> openWatch: false<br/> } </p> <my-class :data="listData2" :class-option="classOption2" @copy-data="listData2 = listData2.concat(listData2)" class="warp"> <ul class="item"> <li v-for="item in listData2"><span class="title" v-text="item.title"></span><span class="date" v-text="item.date"></span></li> </ul> </my-class> </p> <p class="flex wd800"> <p class="options" style="color:#357edd;"> <p><b>demo4</b> 向下滚动,禁止了hover悬停</p> var option = {<br/> limitMoveNum: 5,<br/> direction: 0,<br/> hoverStop: false,<br/> } </p> <my-class :data="listData3" :class-option="classOption3" @copy-data="listData3 = listData3.concat(listData3)" class="warp"> <ul class="item"> <li v-for="item in listData3"><span class="title" v-text="item.title"></span><span class="date" v-text="item.date"></span></li> </ul> </my-class> </p> <p class="flex wd800"> <p class="options" style="color:#357edd;"> <p><b>demo5</b> 向上无缝滚动,单条停止一段时间</p> var option = {<br/> step: 0.5,<br/> limitMoveNum: 5<br/> singleHeight: 30,<br/> waitTime: 1000<br/> } </p> <my-class :data="listData4" :class-option="classOption4" @copy-data="listData4 = listData4.concat(listData4)" class="warp"> <ul class="item"> <li v-for="item in listData4"><span class="title" v-text="item.title"></span><span class="date" v-text="item.date"></span> </li> </ul> </my-class> </p> </p> </template> <script> import myClass from '../src/components/myClass.vue' export default { name: 'app', data () { return { listData: [{ 'title': '无缝滚动第一行无缝滚动第一行', 'date': '2017-12-16' }, { 'title': '无缝滚动第二行无缝滚动第二行', 'date': '2017-12-16' }, { 'title': '无缝滚动第三行无缝滚动第三行', 'date': '2017-12-16' }, { 'title': '无缝滚动第四行无缝滚动第四行', 'date': '2017-12-16' }, { 'title': '无缝滚动第五行无缝滚动第五行', 'date': '2017-12-16' }, { 'title': '无缝滚动第六行无缝滚动第六行', 'date': '2017-12-16' }, { 'title': '无缝滚动第七行无缝滚动第七行', 'date': '2017-12-16' }, { 'title': '无缝滚动第八行无缝滚动第八行', 'date': '2017-12-16' }, { 'title': '无缝滚动第九行无缝滚动第九行', 'date': '2017-12-16' }], listData1: [{ 'title': '无缝滚动第一行无缝滚动第一行', 'date': '2017-12-16' }, { 'title': '无缝滚动第二行无缝滚动第二行', 'date': '2017-12-16' }, { 'title': '无缝滚动第三行无缝滚动第三行', 'date': '2017-12-16' }, { 'title': '无缝滚动第四行无缝滚动第四行', 'date': '2017-12-16' }, { 'title': '无缝滚动第五行无缝滚动第五行', 'date': '2017-12-16' }, { 'title': '无缝滚动第六行无缝滚动第六行', 'date': '2017-12-16' }], listData2: [{ 'title': '无缝滚动第一行无缝滚动第一行', 'date': '2017-12-16' }, { 'title': '无缝滚动第二行无缝滚动第二行', 'date': '2017-12-16' }, { 'title': '无缝滚动第三行无缝滚动第三行', 'date': '2017-12-16' }, { 'title': '无缝滚动第四行无缝滚动第四行', 'date': '2017-12-16' }, { 'title': '无缝滚动第五行无缝滚动第五行', 'date': '2017-12-16' }, { 'title': '无缝滚动第六行无缝滚动第六行', 'date': '2017-12-16' }], listData3: [{ 'title': '无缝滚动第一行无缝滚动第一行', 'date': '2017-12-16' }, { 'title': '无缝滚动第二行无缝滚动第二行', 'date': '2017-12-16' }, { 'title': '无缝滚动第三行无缝滚动第三行', 'date': '2017-12-16' }, { 'title': '无缝滚动第四行无缝滚动第四行', 'date': '2017-12-16' }, { 'title': '无缝滚动第五行无缝滚动第五行', 'date': '2017-12-16' }, { 'title': '无缝滚动第六行无缝滚动第六行', 'date': '2017-12-16' }, { 'title': '无缝滚动第七行无缝滚动第七行', 'date': '2017-12-16' }, { 'title': '无缝滚动第八行无缝滚动第八行', 'date': '2017-12-16' }], listData4: [{ 'title': '无缝滚动第一行无缝滚动第一行', 'date': '2017-12-16' }, { 'title': '无缝滚动第二行无缝滚动第二行', 'date': '2017-12-16' }, { 'title': '无缝滚动第三行无缝滚动第三行', 'date': '2017-12-16' }, { 'title': '无缝滚动第四行无缝滚动第四行', 'date': '2017-12-16' }, { 'title': '无缝滚动第五行无缝滚动第五行', 'date': '2017-12-16' }, { 'title': '无缝滚动第六行无缝滚动第六行', 'date': '2017-12-16' }, { 'title': '无缝滚动第七行无缝滚动第七行', 'date': '2017-12-16' }, { 'title': '无缝滚动第八行无缝滚动第八行', 'date': '2017-12-16' }, { 'title': '无缝滚动第九行无缝滚动第九行', 'date': '2017-12-16' }], } }, computed: { classOption () { return { step: 0.5, limitMoveNum: 5 } }, classOption1 () { return { limitMoveNum: 7 } }, classOption2 () { return { limitMoveNum: 7, openWatch: false } }, classOption3 () { return { limitMoveNum: 5, direction: 0, hoverStop: false } }, classOption4 () { return { step: 0.5, limitMoveNum: 5, singleHeight: 30, waitTime: 1000 } } }, components: { myClass }, created () { setTimeout(() => { this.listData1 = this.listData2 = [{ 'title': '无缝滚动第一行无缝滚动第一行', 'date': '2017-12-16' }, { 'title': '无缝滚动第二行无缝滚动第二行', 'date': '2017-12-16' }, { 'title': '无缝滚动第三行无缝滚动第三行', 'date': '2017-12-16' }, { 'title': '无缝滚动第四行无缝滚动第四行', 'date': '2017-12-16' }, { 'title': '无缝滚动第五行无缝滚动第五行', 'date': '2017-12-16' }, { 'title': '无缝滚动第六行无缝滚动第六行', 'date': '2017-12-16' }, { 'title': '无缝滚动第七行无缝滚动第七行', 'date': '2017-12-16' }, { 'title': '无缝滚动第八行无缝滚动第八行', 'date': '2017-12-16' }, { 'title': '无缝滚动第九行无缝滚动第九行', 'date': '2017-12-16' }] }, 3000) } } </script> <style lang="scss"> #app { padding-bottom: 100px; } .flex-fill { -ms-flex: 1 1; flex: 1 1; } .options { width: 300px; font-size: 15px; margin-right: 60px; p { color: #000; margin-bottom: 30px; b { font-size: 16px; font-style: italic; } } } .wd800 { width: 800px; margin: 30px auto; } .warp { height: 260px; width: 360px; overflow: hidden; ul { list-style: none; padding: 0; margin: 0 auto; li { height: 30px; line-height: 30px; display: flex; justify-content: space-between; font-size: 15px; } } } @media screen and (max-width: 770px) { .warp { width: 90%; margin: 0 auto; } body { background-color: lightblue; } .wd800 { width: 100%; } .flex.wd800 { display: block; } .options { width: 90%; margin: 20px auto; p { margin-bottom:0; } } } </style>
import Vue from 'vue' import vueSeamlessScroll from 'vue-seamless-scroll' new Vue({ components: { vueSeamlessScroll } })
일반 모드(스크립트 태그)
예:
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> .warp { height: 260px; width: 360px; overflow: hidden; } .warp ul { list-style: none; padding: 0; margin: 0 auto; } .warp li { height: 30px; line-height: 30px; display: flex; justify-content: space-between; font-size: 15px; } </style> </head> <body> <p id="app"> <vue-seamless-scroll :data="listData" :class-option="classOption" @copy-data="listData = listData.concat(listData)" class="warp"> <ul class="item"> <li v-for="item in listData"><span class="title" v-text="item.title"></span><span class="date" v-text="item.date"></span> </li> </ul> </vue-seamless-scroll> </p> <script src="https://cdn.bootcss.com/vue/2.5.9/vue.js"></script> <script src="../dist/vue-seamless-scroll.min.js"></script> <script> new Vue({ el: '#app', data: { listData: [{ 'title': '无缝滚动第一行无缝滚动第一行', 'date': '2017-12-16' }, { 'title': '无缝滚动第二行无缝滚动第二行', 'date': '2017-12-16' }, { 'title': '无缝滚动第三行无缝滚动第三行', 'date': '2017-12-16' }, { 'title': '无缝滚动第四行无缝滚动第四行', 'date': '2017-12-16' }, { 'title': '无缝滚动第五行无缝滚动第五行', 'date': '2017-12-16' }, { 'title': '无缝滚动第六行无缝滚动第六行', 'date': '2017-12-16' }, { 'title': '无缝滚动第七行无缝滚动第七行', 'date': '2017-12-16' }, { 'title': '无缝滚动第八行无缝滚动第八行', 'date': '2017-12-16' }, { 'title': '无缝滚动第九行无缝滚动第九行', 'date': '2017-12-16' }] }, computed: { classOption: function () { return { step: 0.5, limitMoveNum: 5 } } } }) </script> </body> </html>
구성
<html> <head> ... </head> <body> <p id="app"> <vue-seamless-scroll></vue-seamless-scroll> </p> <script src="vue.js"></script> <script src="vue-seamless-scroll"></script> <script> new Vue({ el: '#app' }) </script> </body> </html>
위 내용을 정리했습니다. 앞으로 도움이 되길 바랍니다.
관련 기사:
Javascript에서 클래스, 생성자 및 팩토리 함수를 사용하는 방법
nodeJS를 사용하여 WeChat 공유를 구현하는 방법
in Vue .js에서 모바일 구성 요소 라이브러리를 사용하는 방법(자세한 튜토리얼)
Angular2의 URL에서 # 기호를 제거하는 방법(자세한 튜토리얼)
위 내용은 Vue를 사용하여 원활한 스크롤 구성 요소를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











HTML 템플릿의 버튼을 메소드에 바인딩하여 VUE 버튼에 함수를 추가 할 수 있습니다. 메소드를 정의하고 VUE 인스턴스에서 기능 로직을 작성하십시오.

vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

vue.js에서 JS 파일을 참조하는 세 가지 방법이 있습니다. & lt; script & gt; 꼬리표;; mounted () 라이프 사이클 후크를 사용한 동적 가져 오기; Vuex State Management Library를 통해 수입.

vue.js의 시계 옵션을 사용하면 개발자가 특정 데이터의 변경 사항을들을 수 있습니다. 데이터가 변경되면 콜백 기능을 트리거하여 업데이트보기 또는 기타 작업을 수행합니다. 구성 옵션에는 즉시 콜백을 실행할지 여부와 DEEP를 지정하는 즉시 포함되며, 이는 객체 또는 어레이에 대한 변경 사항을 재귀 적으로 듣는 지 여부를 지정합니다.

vue.js는 이전 페이지로 돌아갈 수있는 네 가지 방법이 있습니다. $ router.go (-1) $ router.back () 사용 & lt; router-link to = & quot;/quot; Component Window.history.back () 및 메소드 선택은 장면에 따라 다릅니다.

CSS 애니메이션 또는 타사 라이브러리를 사용하여 VUE에서 Marquee/Text Scrolling Effects를 구현하십시오. 이 기사는 CSS 애니메이션 사용 방법을 소개합니다. & lt; div & gt; CSS 애니메이션을 정의하고 오버플로를 설정하십시오 : 숨겨진, 너비 및 애니메이션. 키 프레임을 정의하고 변환을 설정하십시오 : Translatex () 애니메이션의 시작과 끝에서. 지속 시간, 스크롤 속도 및 방향과 같은 애니메이션 속성을 조정하십시오.

Pagination은 큰 데이터 세트를 작은 페이지로 나누어 성능 및 사용자 경험을 향상시키는 기술입니다. VUE에서 다음 내장 방법을 페이징에 사용할 수 있습니다. 총 페이지 수를 계산하십시오 : TotalPages () Traversal 페이지 번호 : V-For Directive 현재 페이지를 설정하려면 : CurrentPage 현재 페이지 데이터 가져 오기 : currentPagedAta ()

VUE의 기능 차단은 지정된 기간 내에 기능이 호출되는 횟수를 제한하고 성능 문제를 방지하는 데 사용되는 기술입니다. 구현 방법은 다음과 같습니다. lodash 라이브러리 가져 오기 : 'lodash'에서 import {debounce}; Debounce 기능을 사용하여 인터셉트 기능을 만듭니다. const debouncedfunction = debounce (() = & gt; { / logical /}, 500); 인터셉트 함수를 호출하면 제어 기능이 최대 500 밀리 초 안에 한 번 호출됩니다.
