From 7520eb0bf1837119d09f875d79e6ead17f561f1f Mon Sep 17 00:00:00 2001 From: dengwen49 Date: Mon, 14 Oct 2019 21:40:20 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0main=E7=9B=AE=E5=BD=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- main/README.md | 143 ++++++++++++++ main/bus.js | 14 ++ main/es5/bus.js | 14 ++ main/es5/index.js | 34 ++++ main/index.js | 34 ++++ main/package.json | 66 +++++++ main/waterfall.vue | 473 +++++++++++++++++++++++++++++++++++++++++++++ 7 files changed, 778 insertions(+) create mode 100644 main/README.md create mode 100644 main/bus.js create mode 100644 main/es5/bus.js create mode 100644 main/es5/index.js create mode 100644 main/index.js create mode 100644 main/package.json create mode 100644 main/waterfall.vue diff --git a/main/README.md b/main/README.md new file mode 100644 index 0000000..bacdb7b --- /dev/null +++ b/main/README.md @@ -0,0 +1,143 @@ + + + +#### [中文版文档](https://github.com/AwesomeDevin/vue-waterfall2/blob/master/CHINESE-README.md) +# vue-waterfall2 + 1. auto adaption for width and height + 2. High degree of customization + 3. support lazy load(attribute with `lazy-src`) + +![The demo on mobile device](https://raw.githubusercontent.com/AwesomeDevin/vue-waterfall2/master/src/assets/gifhome_240x514_17s.gif) + + +If you have some questions,welcome to describe issues、suggestions;Thank you for your Star ! +[Welcome to my blog !!!](https://github.com/AwesomeDevin/blog) + + +## Demo +[Common Demo](http://47.105.188.15:3001/) +[Lazyload Demo](http://47.105.188.15:3001/#/list) +[Code Demo](https://codesandbox.io/embed/vue-template-99ps6) + + + + + +[GITHUB](https://github.com/Rise-Devin/vue-waterfall2) +``` +npm i +npm run dev +``` + +## Installation +``` + npm i vue-waterfall2@latest --save +``` + +## Props +Name | Default | Type | Desc +-------- | -------- | -------- | -------- +height | null | Number | height of container +col | 2 | Number | The number of column +width | null | Number | The width of each column +gutterWidth | 10 | Number | The value of margin +data | [] | Array | data +isTransition | true | Boolean | load image with transition +lazyDistance | 300 | Number | The distance of image lazy loading +loadDistance | 300 | Number | The distance of loadmore + +## Lazy Load +For images that need to be loaded lazily, the 'lazy-src' attribute needs to be used +```html + + + +``` + +## Events +Name | Data | Desc +-------- | --- | -------- +loadmore | - | Scroll to the bottom to trigger on PC / pull up to trigger on Mobile +scroll | obj | Scroll to trigger and get the infomation of scroll +finish | - | finish render + +## $waterfall API +``` +this.$waterfall.forceUpdate() //forceUpdate +``` + +## Usage +Notes: + 1. attribute `gutterWidth` needs to be used together with `width` to be effective, otherwise it will be adaptive width (when using `rem` to layout, calculate the width after adaptation before passing the value). + 2. Use the parent component of 'waterfall' if there is a problem with the style, remove CSS `scoped` and try it +##### main.js +```javascript +import waterfall from 'vue-waterfall2' +Vue.use(waterfall) +``` +##### app.vue +```javascript + + + +/* + notes: + 1. attribute `gutterWidth` needs to be used together with `width` to be effective, otherwise it will be adaptive width (when using `rem` to layout, calculate the width after adaptation before passing the value). + 2. Use the parent component of 'waterfall' if there is a problem with the style, remove CSS 'scoped' and try it +*/ + +import Vue from 'vue' + export default{ + data(){ + return{ + data:[], + col:5, + } + }, + computed:{ + itemWidth(){ + return (138*0.5*(document.documentElement.clientWidth/375)) #rem to layout, Calculate the value of width + }, + gutterWidth(){ + return (9*0.5*(document.documentElement.clientWidth/375)) #rem to layout, Calculate the value of margin + } + }, + methods:{ + scroll(scrollData){ + console.log(scrollData) + }, + switchCol(col){ + this.col = col + console.log(this.col) + }, + loadmore(index){ + this.data = this.data.concat(this.data) + } + } + } +``` diff --git a/main/bus.js b/main/bus.js new file mode 100644 index 0000000..95952ba --- /dev/null +++ b/main/bus.js @@ -0,0 +1,14 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _vue = require('vue'); + +var _vue2 = _interopRequireDefault(_vue); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var Bus = new _vue2.default(); +exports.default = Bus; \ No newline at end of file diff --git a/main/es5/bus.js b/main/es5/bus.js new file mode 100644 index 0000000..95952ba --- /dev/null +++ b/main/es5/bus.js @@ -0,0 +1,14 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _vue = require('vue'); + +var _vue2 = _interopRequireDefault(_vue); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var Bus = new _vue2.default(); +exports.default = Bus; \ No newline at end of file diff --git a/main/es5/index.js b/main/es5/index.js new file mode 100644 index 0000000..7cba934 --- /dev/null +++ b/main/es5/index.js @@ -0,0 +1,34 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _bus = require('./bus.js'); + +var _bus2 = _interopRequireDefault(_bus); + +var _waterfall = require('./waterfall.vue'); + +var _waterfall2 = _interopRequireDefault(_waterfall); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var Index = { + install: function install(Vue) { + if (this.installed) { + return; + } + this.installed = true; + Vue.component('waterfall', _waterfall2.default); + Vue.prototype.$waterfall = { + resize: function resize() { + _bus2.default.$emit('resize'); + }, + mix: function mix() { + _bus2.default.$emit('mix'); + } + }; + } +}; +exports.default = Index; \ No newline at end of file diff --git a/main/index.js b/main/index.js new file mode 100644 index 0000000..ac69640 --- /dev/null +++ b/main/index.js @@ -0,0 +1,34 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _bus = require('./bus.js'); + +var _bus2 = _interopRequireDefault(_bus); + +var _waterfall = require('./waterfall.vue'); + +var _waterfall2 = _interopRequireDefault(_waterfall); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var Index = { + install: function install(Vue) { + if (this.installed) { + return; + } + this.installed = true; + Vue.component('waterfall', _waterfall2.default); + Vue.prototype.$waterfall = { + forceUpdate: function forceUpdate() { + _bus2.default.$emit('forceUpdate'); + }, + mix: function mix() { + _bus2.default.$emit('mix'); + } + }; + } +}; +exports.default = Index; \ No newline at end of file diff --git a/main/package.json b/main/package.json new file mode 100644 index 0000000..d047c65 --- /dev/null +++ b/main/package.json @@ -0,0 +1,66 @@ +{ + "_args": [ + [ + "vue-waterfall2@1.9.1", + "D:\\projects\\act\\proj\\2018\\1112_findv2" + ] + ], + "_from": "vue-waterfall2@1.9.1", + "_id": "vue-waterfall2@1.9.1", + "_inBundle": false, + "_integrity": "sha512-fMJq9LJwb6/0AciO7IqQNZb+fEkzpkyzOhugT+POndGAEGWpallLw6yDc0ZfKJ/AmStD+gPyvSLv8UY4KBnfEg==", + "_location": "/vue-waterfall2", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "vue-waterfall2@^1.9.1", + "name": "vue-waterfall2", + "escapedName": "vue-waterfall2", + "rawSpec": "^1.9.1", + "saveSpec": null, + "fetchSpec": "^1.9.1" + }, + "_requiredBy": [ + "#DEV:/" + ], + "_resolved": "https://registry.npm.taobao.org/vue-waterfall2/download/vue-waterfall2-1.9.1.tgz", + "_shasum": "0793f2abead08383d15e072880017858cbdf3223", + "_spec": "vue-waterfall2@^1.9.1", + "_where": "E:\\projects\\work\\vue-waterfall", + "author": { + "name": "daivonup@gmail.com" + }, + "bugs": { + "url": "https://github.com/Rise-Devin/vue-waterfall2/issues" + }, + "bundleDependencies": false, + "dependencies": { + "babel-runtime": "^6.26.0", + "regenerator-runtime": "^0.13.1" + }, + "deprecated": false, + "description": "vue plugin for waterfall", + "devDependencies": { + "babel-polyfill": "^6.26.0", + "babel-preset-es2015": "^6.24.1", + "vue": "^2.5.2" + }, + "homepage": "https://github.com/Rise-Devin/vue-waterfall2#readme", + "keywords": [ + "waterfall", + "vue" + ], + "license": "MIT", + "main": "index.js", + "name": "vue-waterfall2", + "repository": { + "type": "git", + "url": "git+https://github.com/Rise-Devin/vue-waterfall2.git" + }, + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "version": "1.9.1", + "__npminstall_done": "Mon Oct 14 2019 20:59:33 GMT+0800 (GMT+08:00)" +} \ No newline at end of file diff --git a/main/waterfall.vue b/main/waterfall.vue new file mode 100644 index 0000000..68cebbd --- /dev/null +++ b/main/waterfall.vue @@ -0,0 +1,473 @@ + + + + \ No newline at end of file