├── .babelrc ├── .editorconfig ├── .eslintignore ├── .eslintrc.js ├── .gitignore ├── .postcssrc.js ├── LICENSE ├── README.md ├── build ├── build.js ├── check-versions.js ├── dev-client.js ├── dev-server.js ├── utils.js ├── vue-loader.conf.js ├── webpack.base.conf.js ├── webpack.dev.conf.js └── webpack.prod.conf.js ├── config ├── dev.env.js ├── index.js └── prod.env.js ├── dist ├── app.js ├── app.json ├── app.wxss ├── common │ ├── manifest.js │ └── vendor.js ├── components │ ├── articleList.vue.wxml │ ├── commentList.vue.wxml │ ├── loading.vue.wxml │ ├── slots.wxml │ └── themeList.vue.wxml └── pages │ ├── comment │ ├── index.vue.wxml │ ├── main.js │ ├── main.json │ ├── main.wxml │ └── main.wxss │ ├── detail │ ├── index.vue.wxml │ ├── main.js │ ├── main.json │ ├── main.wxml │ └── main.wxss │ ├── index │ ├── index.vue.wxml │ ├── main.js │ ├── main.json │ ├── main.wxml │ └── main.wxss │ └── theme │ ├── index.vue.wxml │ ├── main.js │ ├── main.json │ ├── main.wxml │ └── main.wxss ├── index.html ├── package-lock.json ├── package.json ├── project.config.json ├── screenshots ├── comment.png ├── detail.png ├── index.png └── theme.png ├── src ├── App.vue ├── api │ └── index.js ├── app.json ├── assets │ ├── iconfont │ │ ├── iconfont.css │ │ ├── iconfont.eot │ │ ├── iconfont.js │ │ ├── iconfont.svg │ │ ├── iconfont.ttf │ │ └── iconfont.woff │ └── index.styl ├── components │ ├── articleList.vue │ ├── commentList.vue │ ├── loading.vue │ └── themeList.vue ├── main.js ├── pages │ ├── comment │ │ ├── index.vue │ │ ├── main.js │ │ └── main.json │ ├── detail │ │ ├── index.vue │ │ ├── main.js │ │ └── main.json │ ├── index │ │ ├── index.vue │ │ ├── main.js │ │ └── main.json │ └── theme │ │ ├── index.vue │ │ ├── main.js │ │ └── main.json └── utils │ ├── index.js │ └── request.js └── static └── .gitkeep /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": [ 3 | ["env", { 4 | "modules": false, 5 | "targets": { 6 | "browsers": ["> 1%", "last 2 versions", "not ie <= 8"] 7 | } 8 | }], 9 | "stage-2" 10 | ], 11 | "plugins": ["transform-runtime"], 12 | "env": { 13 | "test": { 14 | "presets": ["env", "stage-2"], 15 | "plugins": ["istanbul"] 16 | } 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | charset = utf-8 5 | indent_style = space 6 | indent_size = 2 7 | end_of_line = lf 8 | insert_final_newline = true 9 | trim_trailing_whitespace = true 10 | -------------------------------------------------------------------------------- /.eslintignore: -------------------------------------------------------------------------------- 1 | build/*.js 2 | config/*.js 3 | -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | // http://eslint.org/docs/user-guide/configuring 2 | 3 | module.exports = { 4 | root: true, 5 | parser: 'babel-eslint', 6 | parserOptions: { 7 | sourceType: 'module' 8 | }, 9 | env: { 10 | browser: false, 11 | node: true, 12 | es6: true 13 | }, 14 | // https://github.com/standard/standard/blob/master/docs/RULES-en.md 15 | extends: 'standard', 16 | // required to lint *.vue files 17 | plugins: [ 18 | 'html' 19 | ], 20 | // add your custom rules here 21 | 'rules': { 22 | // allow paren-less arrow functions 23 | 'arrow-parens': 0, 24 | // allow async-await 25 | 'generator-star-spacing': 0, 26 | // allow debugger during development 27 | 'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0, 28 | 'no-undef': 0, 29 | 'indent': 0, 30 | 'camelcase': 0, 31 | 'space-before-function-paren': 0 32 | }, 33 | globals: { 34 | App: true, 35 | Page: true, 36 | wx: true, 37 | getApp: true, 38 | getPage: true, 39 | requirePlugin: true 40 | } 41 | } 42 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules/ 3 | npm-debug.log* 4 | yarn-debug.log* 5 | yarn-error.log* 6 | 7 | # Editor directories and files 8 | .idea 9 | *.suo 10 | *.ntvs* 11 | *.njsproj 12 | *.sln 13 | -------------------------------------------------------------------------------- /.postcssrc.js: -------------------------------------------------------------------------------- 1 | // https://github.com/michael-ciniawsky/postcss-load-config 2 | 3 | module.exports = { 4 | "plugins": { 5 | "postcss-mpvue-wxss": {} 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 uncleLian 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # mpvue-wechat-zhihu 2 | 3 | ![image](https://img.shields.io/badge/mpvue-1.0.11-blue.svg) 4 | ![image](https://img.shields.io/badge/flyio-0.6.0-green.svg) 5 | 6 | > mpvue-wechat-zhihu 是一个入门级别的资讯类微信小程序,共4个页面,涉及今日文章、主题文章、文章阅读、文章分享、评论阅读等 7 | 8 | ## 资源 9 | - [mpvue(基于vue的小程序框架)](https://github.com/Meituan-Dianping/mpvue) 10 | - [flyio(跨端请求库)](https://github.com/wendux/fly) 11 | - [知乎日报Api](https://github.com/izzyleung/ZhihuDailyPurify/wiki/%E7%9F%A5%E4%B9%8E%E6%97%A5%E6%8A%A5-API-%E5%88%86%E6%9E%90) 12 | - [微信开发者工具](https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html) 13 | - [微信小程序文档](https://developers.weixin.qq.com/miniprogram/dev/) 14 | - [Stylus(css预处理器)](https://github.com/stylus/stylus) 15 | - [IconFont(阿里图标库)](http://www.iconfont.cn/) 16 | 17 | ## 扫码体验 18 | 19 | > 审核结果:小程序当前页面涉及个人小程序未允许内容:文娱-资讯,建议申请企业主体小程序(2018-08-22) 20 | 21 | > 审核中(2018-08-21 提交) 22 | 23 | ## 截图 24 | 25 | ![image](https://github.com/uncleLian/mpvue-wechat-zhihu/raw/master/screenshots/index.png) ![image](https://github.com/uncleLian/mpvue-wechat-zhihu/raw/master/screenshots/theme.png) 26 | 27 | ![image](https://github.com/uncleLian/mpvue-wechat-zhihu/raw/master/screenshots/detail.png) ![image](https://github.com/uncleLian/mpvue-wechat-zhihu/raw/master/screenshots/comment.png) 28 | 29 | ## 运行 30 | 31 | ##### 前序准备:[微信开发者工具](https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html) 32 | 33 | #### 一、克隆项目 34 | ```bash 35 | git clone https://github.com/uncleLian/mpvue-wechat-zhihu.git 36 | ``` 37 | #### 二、打开微信开发者工具导入小程序 38 | ``` 39 | 项目目录:/dist 目录 40 | AppID:选择测试小程序 41 | 项目名称:随意 42 | ``` 43 | 44 | #### 三、勾选以下选项 45 | 打开项目报错:请求URL不在合法域名列表中 46 | ```bash 47 | [✔] 不校验合法域名、web-view(业务域名)、TLS 版本以及 HTTPS 证书 48 | ``` 49 | #### 四、真机体验 50 | 开发者工具上方点击预览按钮,构建出二维码,微信扫码体验 51 | 52 | ## 开发和发布 53 | ```bash 54 | # 安装依赖 55 | npm install 56 | 57 | # 启动服务(开发调试) 58 | npm run dev 59 | 60 | # 构建正式发布的小程序代码 61 | npm run build 62 | ``` 63 | ##### 注:通过mpvue构建的小程序代码在 /dist 目录 64 | 65 | ## 目录 66 | ```js 67 | ├── build 68 | ├── config 69 | ├── dist // 小程序代码 70 | ├── src 71 | │   ├── api // 请求api 72 | │   ├── assets // 静态资源 73 | │   ├── components // 组件 74 | │   ├── pages // 页面 75 | │   │   ├── comment 76 | │   │   ├── detail 77 | │   │   ├── index 78 | │   │   └── theme 79 | │   └── utils // 工具 80 | │   ├── app.json // 小程序配置 81 | │   ├── App.vue 82 | │   ├── main.js 83 | ``` 84 | 85 | ## 说明 86 | > 如果对你有帮助,你可以点右上角 "star"支持一下,非常感谢!🌹 87 | 88 | > 或者你可以 "follow(关注)" 一下作者,我正在不断开源更多实用的项目 89 | 90 | > 你可以从我其他的项目或者star里面找到很多不错的知识点和前端库 91 | 92 | > 如有问题可以直接在 Issues 中反馈,或者加入我们下方的Vue群更进一步地交流(请填写获知来源) 93 | 94 | ## 交流 95 | 欢迎热爱学习、忠于分享的朋友一起来交流 96 | - Vue交流群:338241465 97 | 98 | ## License 99 | [MIT](http://opensource.org/licenses/MIT) 100 | 101 | Copyright (c) 2018-present,uncleLian 102 | -------------------------------------------------------------------------------- /build/build.js: -------------------------------------------------------------------------------- 1 | require('./check-versions')() 2 | 3 | process.env.NODE_ENV = 'production' 4 | 5 | var ora = require('ora') 6 | var rm = require('rimraf') 7 | var path = require('path') 8 | var chalk = require('chalk') 9 | var webpack = require('webpack') 10 | var config = require('../config') 11 | var webpackConfig = require('./webpack.prod.conf') 12 | 13 | var spinner = ora('building for production...') 14 | spinner.start() 15 | 16 | rm(path.join(config.build.assetsRoot, '*'), err => { 17 | if (err) throw err 18 | webpack(webpackConfig, function (err, stats) { 19 | spinner.stop() 20 | if (err) throw err 21 | process.stdout.write(stats.toString({ 22 | colors: true, 23 | modules: false, 24 | children: false, 25 | chunks: false, 26 | chunkModules: false 27 | }) + '\n\n') 28 | 29 | if (stats.hasErrors()) { 30 | console.log(chalk.red(' Build failed with errors.\n')) 31 | process.exit(1) 32 | } 33 | 34 | console.log(chalk.cyan(' Build complete.\n')) 35 | console.log(chalk.yellow( 36 | ' Tip: built files are meant to be served over an HTTP server.\n' + 37 | ' Opening index.html over file:// won\'t work.\n' 38 | )) 39 | }) 40 | }) 41 | -------------------------------------------------------------------------------- /build/check-versions.js: -------------------------------------------------------------------------------- 1 | var chalk = require('chalk') 2 | var semver = require('semver') 3 | var packageConfig = require('../package.json') 4 | var shell = require('shelljs') 5 | function exec (cmd) { 6 | return require('child_process').execSync(cmd).toString().trim() 7 | } 8 | 9 | var versionRequirements = [ 10 | { 11 | name: 'node', 12 | currentVersion: semver.clean(process.version), 13 | versionRequirement: packageConfig.engines.node 14 | } 15 | ] 16 | 17 | if (shell.which('npm')) { 18 | versionRequirements.push({ 19 | name: 'npm', 20 | currentVersion: exec('npm --version'), 21 | versionRequirement: packageConfig.engines.npm 22 | }) 23 | } 24 | 25 | module.exports = function () { 26 | var warnings = [] 27 | for (var i = 0; i < versionRequirements.length; i++) { 28 | var mod = versionRequirements[i] 29 | if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) { 30 | warnings.push(mod.name + ': ' + 31 | chalk.red(mod.currentVersion) + ' should be ' + 32 | chalk.green(mod.versionRequirement) 33 | ) 34 | } 35 | } 36 | 37 | if (warnings.length) { 38 | console.log('') 39 | console.log(chalk.yellow('To use this template, you must update following to modules:')) 40 | console.log() 41 | for (var i = 0; i < warnings.length; i++) { 42 | var warning = warnings[i] 43 | console.log(' ' + warning) 44 | } 45 | console.log() 46 | process.exit(1) 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /build/dev-client.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable */ 2 | require('eventsource-polyfill') 3 | var hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true') 4 | 5 | hotClient.subscribe(function (event) { 6 | if (event.action === 'reload') { 7 | window.location.reload() 8 | } 9 | }) 10 | -------------------------------------------------------------------------------- /build/dev-server.js: -------------------------------------------------------------------------------- 1 | require('./check-versions')() 2 | 3 | var config = require('../config') 4 | if (!process.env.NODE_ENV) { 5 | process.env.NODE_ENV = JSON.parse(config.dev.env.NODE_ENV) 6 | } 7 | 8 | // var opn = require('opn') 9 | var path = require('path') 10 | var express = require('express') 11 | var webpack = require('webpack') 12 | var proxyMiddleware = require('http-proxy-middleware') 13 | var portfinder = require('portfinder') 14 | var webpackConfig = require('./webpack.dev.conf') 15 | 16 | // default port where dev server listens for incoming traffic 17 | var port = process.env.PORT || config.dev.port 18 | // automatically open browser, if not set will be false 19 | var autoOpenBrowser = !!config.dev.autoOpenBrowser 20 | // Define HTTP proxies to your custom API backend 21 | // https://github.com/chimurai/http-proxy-middleware 22 | var proxyTable = config.dev.proxyTable 23 | 24 | var app = express() 25 | var compiler = webpack(webpackConfig) 26 | 27 | // var devMiddleware = require('webpack-dev-middleware')(compiler, { 28 | // publicPath: webpackConfig.output.publicPath, 29 | // quiet: true 30 | // }) 31 | 32 | // var hotMiddleware = require('webpack-hot-middleware')(compiler, { 33 | // log: false, 34 | // heartbeat: 2000 35 | // }) 36 | // force page reload when html-webpack-plugin template changes 37 | // compiler.plugin('compilation', function (compilation) { 38 | // compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) { 39 | // hotMiddleware.publish({ action: 'reload' }) 40 | // cb() 41 | // }) 42 | // }) 43 | 44 | // proxy api requests 45 | Object.keys(proxyTable).forEach(function (context) { 46 | var options = proxyTable[context] 47 | if (typeof options === 'string') { 48 | options = { target: options } 49 | } 50 | app.use(proxyMiddleware(options.filter || context, options)) 51 | }) 52 | 53 | // handle fallback for HTML5 history API 54 | app.use(require('connect-history-api-fallback')()) 55 | 56 | // serve webpack bundle output 57 | // app.use(devMiddleware) 58 | 59 | // enable hot-reload and state-preserving 60 | // compilation error display 61 | // app.use(hotMiddleware) 62 | 63 | // serve pure static assets 64 | var staticPath = path.posix.join(config.dev.assetsPublicPath, config.dev.assetsSubDirectory) 65 | app.use(staticPath, express.static('./static')) 66 | 67 | // var uri = 'http://localhost:' + port 68 | 69 | var _resolve 70 | var readyPromise = new Promise(resolve => { 71 | _resolve = resolve 72 | }) 73 | 74 | // console.log('> Starting dev server...') 75 | // devMiddleware.waitUntilValid(() => { 76 | // console.log('> Listening at ' + uri + '\n') 77 | // // when env is testing, don't need open it 78 | // if (autoOpenBrowser && process.env.NODE_ENV !== 'testing') { 79 | // opn(uri) 80 | // } 81 | // _resolve() 82 | // }) 83 | 84 | module.exports = new Promise((resolve, reject) => { 85 | portfinder.basePort = port 86 | portfinder.getPortPromise() 87 | .then(newPort => { 88 | if (port !== newPort) { 89 | console.log(`${port}端口被占用,开启新端口${newPort}`) 90 | } 91 | var server = app.listen(newPort, 'localhost') 92 | // for 小程序的文件保存机制 93 | require('webpack-dev-middleware-hard-disk')(compiler, { 94 | publicPath: webpackConfig.output.publicPath, 95 | quiet: true 96 | }) 97 | resolve({ 98 | ready: readyPromise, 99 | close: () => { 100 | server.close() 101 | } 102 | }) 103 | }).catch(error => { 104 | console.log('没有找到空闲端口,请打开任务管理器杀死进程端口再试', error) 105 | }) 106 | }) 107 | -------------------------------------------------------------------------------- /build/utils.js: -------------------------------------------------------------------------------- 1 | var path = require('path') 2 | var config = require('../config') 3 | var ExtractTextPlugin = require('extract-text-webpack-plugin') 4 | 5 | exports.assetsPath = function (_path) { 6 | var assetsSubDirectory = process.env.NODE_ENV === 'production' 7 | ? config.build.assetsSubDirectory 8 | : config.dev.assetsSubDirectory 9 | return path.posix.join(assetsSubDirectory, _path) 10 | } 11 | 12 | exports.cssLoaders = function (options) { 13 | options = options || {} 14 | 15 | var cssLoader = { 16 | loader: 'css-loader', 17 | options: { 18 | minimize: process.env.NODE_ENV === 'production', 19 | sourceMap: options.sourceMap 20 | } 21 | } 22 | 23 | var postcssLoader = { 24 | loader: 'postcss-loader', 25 | options: { 26 | sourceMap: true 27 | } 28 | } 29 | 30 | var px2rpxLoader = { 31 | loader: 'px2rpx-loader', 32 | options: { 33 | baseDpr: 1, 34 | rpxUnit: 0.5 35 | } 36 | } 37 | 38 | // generate loader string to be used with extract text plugin 39 | function generateLoaders(loader, loaderOptions) { 40 | var loaders = [cssLoader, px2rpxLoader, postcssLoader] 41 | if (loader) { 42 | loaders.push({ 43 | loader: loader + '-loader', 44 | options: Object.assign({}, loaderOptions, { 45 | sourceMap: options.sourceMap 46 | }) 47 | }) 48 | } 49 | 50 | // Extract CSS when that option is specified 51 | // (which is the case during production build) 52 | if (options.extract) { 53 | return ExtractTextPlugin.extract({ 54 | use: loaders, 55 | fallback: 'vue-style-loader' 56 | }) 57 | } else { 58 | return ['vue-style-loader'].concat(loaders) 59 | } 60 | } 61 | 62 | // https://vue-loader.vuejs.org/en/configurations/extract-css.html 63 | var cssDir = path.resolve(__dirname, '../src/assets') 64 | return { 65 | css: generateLoaders(), 66 | wxss: generateLoaders(), 67 | postcss: generateLoaders(), 68 | less: generateLoaders('less'), 69 | sass: generateLoaders('sass', { indentedSyntax: true }), 70 | scss: generateLoaders('sass'), 71 | stylus: generateLoaders('stylus', { 72 | import: [cssDir + '/*.styl'] 73 | }), 74 | styl: generateLoaders('stylus') 75 | } 76 | } 77 | 78 | // Generate loaders for standalone style files (outside of .vue) 79 | exports.styleLoaders = function (options) { 80 | var output = [] 81 | var loaders = exports.cssLoaders(options) 82 | for (var extension in loaders) { 83 | var loader = loaders[extension] 84 | output.push({ 85 | test: new RegExp('\\.' + extension + '$'), 86 | use: loader 87 | }) 88 | } 89 | return output 90 | } 91 | -------------------------------------------------------------------------------- /build/vue-loader.conf.js: -------------------------------------------------------------------------------- 1 | var utils = require('./utils') 2 | var config = require('../config') 3 | // var isProduction = process.env.NODE_ENV === 'production' 4 | // for mp 5 | var isProduction = true 6 | 7 | module.exports = { 8 | loaders: utils.cssLoaders({ 9 | sourceMap: isProduction 10 | ? config.build.productionSourceMap 11 | : config.dev.cssSourceMap, 12 | extract: isProduction 13 | }), 14 | transformToRequire: { 15 | video: 'src', 16 | source: 'src', 17 | img: 'src', 18 | image: 'xlink:href' 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /build/webpack.base.conf.js: -------------------------------------------------------------------------------- 1 | var path = require('path') 2 | var fs = require('fs') 3 | var utils = require('./utils') 4 | var config = require('../config') 5 | var vueLoaderConfig = require('./vue-loader.conf') 6 | var MpvuePlugin = require('webpack-mpvue-asset-plugin') 7 | var glob = require('glob') 8 | var CopyWebpackPlugin = require('copy-webpack-plugin') 9 | var relative = require('relative') 10 | 11 | function resolve (dir) { 12 | return path.join(__dirname, '..', dir) 13 | } 14 | 15 | function getEntry (rootSrc) { 16 | var map = {}; 17 | glob.sync(rootSrc + '/pages/**/main.js') 18 | .forEach(file => { 19 | var key = relative(rootSrc, file).replace('.js', ''); 20 | map[key] = file; 21 | }) 22 | return map; 23 | } 24 | 25 | const appEntry = { app: resolve('./src/main.js') } 26 | const pagesEntry = getEntry(resolve('./src'), 'pages/**/main.js') 27 | const entry = Object.assign({}, appEntry, pagesEntry) 28 | 29 | module.exports = { 30 | // 如果要自定义生成的 dist 目录里面的文件路径, 31 | // 可以将 entry 写成 {'toPath': 'fromPath'} 的形式, 32 | // toPath 为相对于 dist 的路径, 例:index/demo,则生成的文件地址为 dist/index/demo.js 33 | entry, 34 | target: require('mpvue-webpack-target'), 35 | output: { 36 | path: config.build.assetsRoot, 37 | filename: '[name].js', 38 | publicPath: process.env.NODE_ENV === 'production' 39 | ? config.build.assetsPublicPath 40 | : config.dev.assetsPublicPath 41 | }, 42 | resolve: { 43 | extensions: ['.js', '.vue', '.json'], 44 | alias: { 45 | 'vue': 'mpvue', 46 | '@': resolve('src') 47 | }, 48 | symlinks: false, 49 | aliasFields: ['mpvue', 'weapp', 'browser'], 50 | mainFields: ['browser', 'module', 'main'] 51 | }, 52 | module: { 53 | rules: [ 54 | { 55 | test: /\.(js|vue)$/, 56 | loader: 'eslint-loader', 57 | enforce: 'pre', 58 | include: [resolve('src'), resolve('test')], 59 | options: { 60 | formatter: require('eslint-friendly-formatter') 61 | } 62 | }, 63 | { 64 | test: /\.vue$/, 65 | loader: 'mpvue-loader', 66 | options: vueLoaderConfig 67 | }, 68 | { 69 | test: /\.js$/, 70 | include: [resolve('src'), resolve('test')], 71 | use: [ 72 | 'babel-loader', 73 | { 74 | loader: 'mpvue-loader', 75 | options: { 76 | checkMPEntry: true 77 | } 78 | }, 79 | ] 80 | }, 81 | { 82 | test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, 83 | loader: 'url-loader', 84 | options: { 85 | limit: 10000, 86 | name: utils.assetsPath('img/[name].[ext]') 87 | } 88 | }, 89 | { 90 | test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/, 91 | loader: 'url-loader', 92 | options: { 93 | limit: 10000, 94 | name: utils.assetsPath('media/[name].[ext]') 95 | } 96 | }, 97 | { 98 | test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, 99 | loader: 'url-loader', 100 | options: { 101 | limit: 10000, 102 | name: utils.assetsPath('fonts/[name].[ext]') 103 | } 104 | } 105 | ] 106 | }, 107 | plugins: [ 108 | new MpvuePlugin(), 109 | new CopyWebpackPlugin([{ 110 | from: '**/*.json', 111 | to: '' 112 | }], { 113 | context: 'src/' 114 | }), 115 | new CopyWebpackPlugin([ 116 | { 117 | from: path.resolve(__dirname, '../static'), 118 | to: path.resolve(__dirname, '../dist/static'), 119 | ignore: ['.*'] 120 | } 121 | ]) 122 | ] 123 | } 124 | -------------------------------------------------------------------------------- /build/webpack.dev.conf.js: -------------------------------------------------------------------------------- 1 | var utils = require('./utils') 2 | var webpack = require('webpack') 3 | var config = require('../config') 4 | var merge = require('webpack-merge') 5 | var baseWebpackConfig = require('./webpack.base.conf') 6 | // var HtmlWebpackPlugin = require('html-webpack-plugin') 7 | var FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin') 8 | 9 | // copy from ./webpack.prod.conf.js 10 | var path = require('path') 11 | var ExtractTextPlugin = require('extract-text-webpack-plugin') 12 | var CopyWebpackPlugin = require('copy-webpack-plugin') 13 | var OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin') 14 | 15 | // add hot-reload related code to entry chunks 16 | // Object.keys(baseWebpackConfig.entry).forEach(function (name) { 17 | // baseWebpackConfig.entry[name] = ['./build/dev-client'].concat(baseWebpackConfig.entry[name]) 18 | // }) 19 | 20 | module.exports = merge(baseWebpackConfig, { 21 | module: { 22 | rules: utils.styleLoaders({ 23 | sourceMap: config.dev.cssSourceMap, 24 | extract: true 25 | }) 26 | }, 27 | // cheap-module-eval-source-map is faster for development 28 | // devtool: '#cheap-module-eval-source-map', 29 | devtool: '#source-map', 30 | output: { 31 | path: config.build.assetsRoot, 32 | // filename: utils.assetsPath('[name].[chunkhash].js'), 33 | // chunkFilename: utils.assetsPath('[id].[chunkhash].js') 34 | filename: utils.assetsPath('[name].js'), 35 | chunkFilename: utils.assetsPath('[id].js') 36 | }, 37 | plugins: [ 38 | new webpack.DefinePlugin({ 39 | 'process.env': config.dev.env 40 | }), 41 | 42 | // copy from ./webpack.prod.conf.js 43 | // extract css into its own file 44 | new ExtractTextPlugin({ 45 | // filename: utils.assetsPath('[name].[contenthash].css') 46 | filename: utils.assetsPath('[name].wxss') 47 | }), 48 | // Compress extracted CSS. We are using this plugin so that possible 49 | // duplicated CSS from different components can be deduped. 50 | new OptimizeCSSPlugin({ 51 | cssProcessorOptions: { 52 | safe: true 53 | } 54 | }), 55 | new webpack.optimize.CommonsChunkPlugin({ 56 | name: 'common/vendor', 57 | minChunks: function (module, count) { 58 | // any required modules inside node_modules are extracted to vendor 59 | return ( 60 | module.resource && 61 | /\.js$/.test(module.resource) && 62 | module.resource.indexOf('node_modules') >= 0 63 | ) || count > 1 64 | } 65 | }), 66 | new webpack.optimize.CommonsChunkPlugin({ 67 | name: 'common/manifest', 68 | chunks: ['common/vendor'] 69 | }), 70 | 71 | // https://github.com/glenjamin/webpack-hot-middleware#installation--usage 72 | // new webpack.HotModuleReplacementPlugin(), 73 | new webpack.NoEmitOnErrorsPlugin(), 74 | // https://github.com/ampedandwired/html-webpack-plugin 75 | // new HtmlWebpackPlugin({ 76 | // filename: 'index.html', 77 | // template: 'index.html', 78 | // inject: true 79 | // }), 80 | new FriendlyErrorsPlugin() 81 | ] 82 | }) 83 | -------------------------------------------------------------------------------- /build/webpack.prod.conf.js: -------------------------------------------------------------------------------- 1 | var path = require('path') 2 | var utils = require('./utils') 3 | var webpack = require('webpack') 4 | var config = require('../config') 5 | var merge = require('webpack-merge') 6 | var baseWebpackConfig = require('./webpack.base.conf') 7 | var UglifyJsPlugin = require('uglifyjs-webpack-plugin') 8 | var CopyWebpackPlugin = require('copy-webpack-plugin') 9 | // var HtmlWebpackPlugin = require('html-webpack-plugin') 10 | var ExtractTextPlugin = require('extract-text-webpack-plugin') 11 | var OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin') 12 | 13 | var env = config.build.env 14 | 15 | var webpackConfig = merge(baseWebpackConfig, { 16 | module: { 17 | rules: utils.styleLoaders({ 18 | sourceMap: config.build.productionSourceMap, 19 | extract: true 20 | }) 21 | }, 22 | devtool: config.build.productionSourceMap ? '#source-map' : false, 23 | output: { 24 | path: config.build.assetsRoot, 25 | // filename: utils.assetsPath('[name].[chunkhash].js'), 26 | // chunkFilename: utils.assetsPath('[id].[chunkhash].js') 27 | filename: utils.assetsPath('[name].js'), 28 | chunkFilename: utils.assetsPath('[id].js') 29 | }, 30 | plugins: [ 31 | // http://vuejs.github.io/vue-loader/en/workflow/production.html 32 | new webpack.DefinePlugin({ 33 | 'process.env': env 34 | }), 35 | new UglifyJsPlugin({ 36 | sourceMap: true 37 | }), 38 | // extract css into its own file 39 | new ExtractTextPlugin({ 40 | // filename: utils.assetsPath('[name].[contenthash].css') 41 | filename: utils.assetsPath('[name].wxss') 42 | }), 43 | // Compress extracted CSS. We are using this plugin so that possible 44 | // duplicated CSS from different components can be deduped. 45 | new OptimizeCSSPlugin({ 46 | cssProcessorOptions: { 47 | safe: true 48 | } 49 | }), 50 | // generate dist index.html with correct asset hash for caching. 51 | // you can customize output by editing /index.html 52 | // see https://github.com/ampedandwired/html-webpack-plugin 53 | // new HtmlWebpackPlugin({ 54 | // filename: config.build.index, 55 | // template: 'index.html', 56 | // inject: true, 57 | // minify: { 58 | // removeComments: true, 59 | // collapseWhitespace: true, 60 | // removeAttributeQuotes: true 61 | // // more options: 62 | // // https://github.com/kangax/html-minifier#options-quick-reference 63 | // }, 64 | // // necessary to consistently work with multiple chunks via CommonsChunkPlugin 65 | // chunksSortMode: 'dependency' 66 | // }), 67 | // keep module.id stable when vender modules does not change 68 | new webpack.HashedModuleIdsPlugin(), 69 | // split vendor js into its own file 70 | new webpack.optimize.CommonsChunkPlugin({ 71 | name: 'common/vendor', 72 | minChunks: function (module, count) { 73 | // any required modules inside node_modules are extracted to vendor 74 | return ( 75 | module.resource && 76 | /\.js$/.test(module.resource) && 77 | module.resource.indexOf('node_modules') >= 0 78 | ) || count > 1 79 | } 80 | }), 81 | // extract webpack runtime and module manifest to its own file in order to 82 | // prevent vendor hash from being updated whenever app bundle is updated 83 | new webpack.optimize.CommonsChunkPlugin({ 84 | name: 'common/manifest', 85 | chunks: ['common/vendor'] 86 | }) 87 | ] 88 | }) 89 | 90 | // if (config.build.productionGzip) { 91 | // var CompressionWebpackPlugin = require('compression-webpack-plugin') 92 | 93 | // webpackConfig.plugins.push( 94 | // new CompressionWebpackPlugin({ 95 | // asset: '[path].gz[query]', 96 | // algorithm: 'gzip', 97 | // test: new RegExp( 98 | // '\\.(' + 99 | // config.build.productionGzipExtensions.join('|') + 100 | // ')$' 101 | // ), 102 | // threshold: 10240, 103 | // minRatio: 0.8 104 | // }) 105 | // ) 106 | // } 107 | 108 | if (config.build.bundleAnalyzerReport) { 109 | var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin 110 | webpackConfig.plugins.push(new BundleAnalyzerPlugin()) 111 | } 112 | 113 | module.exports = webpackConfig 114 | -------------------------------------------------------------------------------- /config/dev.env.js: -------------------------------------------------------------------------------- 1 | var merge = require('webpack-merge') 2 | var prodEnv = require('./prod.env') 3 | 4 | module.exports = merge(prodEnv, { 5 | NODE_ENV: '"development"' 6 | }) 7 | -------------------------------------------------------------------------------- /config/index.js: -------------------------------------------------------------------------------- 1 | // see http://vuejs-templates.github.io/webpack for documentation. 2 | var path = require('path') 3 | 4 | module.exports = { 5 | build: { 6 | env: require('./prod.env'), 7 | index: path.resolve(__dirname, '../dist/index.html'), 8 | assetsRoot: path.resolve(__dirname, '../dist'), 9 | assetsSubDirectory: '', 10 | assetsPublicPath: '/', 11 | productionSourceMap: false, 12 | // Gzip off by default as many popular static hosts such as 13 | // Surge or Netlify already gzip all static assets for you. 14 | // Before setting to `true`, make sure to: 15 | // npm install --save-dev compression-webpack-plugin 16 | productionGzip: false, 17 | productionGzipExtensions: ['js', 'css'], 18 | // Run the build command with an extra argument to 19 | // View the bundle analyzer report after build finishes: 20 | // `npm run build --report` 21 | // Set to `true` or `false` to always turn it on or off 22 | bundleAnalyzerReport: process.env.npm_config_report 23 | }, 24 | dev: { 25 | env: require('./dev.env'), 26 | port: 8080, 27 | // 在小程序开发者工具中不需要自动打开浏览器 28 | autoOpenBrowser: false, 29 | assetsSubDirectory: '', 30 | assetsPublicPath: '/', 31 | proxyTable: {}, 32 | // CSS Sourcemaps off by default because relative paths are "buggy" 33 | // with this option, according to the CSS-Loader README 34 | // (https://github.com/webpack/css-loader#sourcemaps) 35 | // In our experience, they generally work as expected, 36 | // just be aware of this issue when enabling this option. 37 | cssSourceMap: false 38 | } 39 | } 40 | -------------------------------------------------------------------------------- /config/prod.env.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | NODE_ENV: '"production"' 3 | } 4 | -------------------------------------------------------------------------------- /dist/app.js: -------------------------------------------------------------------------------- 1 | require("common/manifest.js"); 2 | require("common/vendor.js"); 3 | global.webpackJsonp([1],{"1vE0":function(t,i,a){"use strict";var s=a("d92L"),e=a("e1aU");var n=function(t){a("Rpv1")},o=a("ybqe")(s.a,e.a,n,"data-v-56c0841f",null);i.a=o.exports},"3cGc":function(t,i,a){"use strict";var s={render:function(){var t=this,i=t.$createElement,a=t._self._c||i;return a("div",{staticClass:"article-list"},[t.date?a("div",{staticClass:"list-date"},[t._v(t._s(t.date))]):t._e(),t._v(" "),t._l(t.json,function(i,s){return a("div",{key:i.id,staticClass:"list-item",attrs:{eventid:"0-"+s},on:{click:function(a){t.url(i)}}},[i.images?a("div",{staticClass:"item-container images"},[a("div",{staticClass:"item-title"},[t._v(t._s(i.title))]),t._v(" "),a("div",{staticClass:"item-images"},[a("img",{attrs:{src:i.images[0]||i.images,mode:"widthFix","lazy-load":!0}})])]):a("div",{staticClass:"item-container text"},[a("div",{staticClass:"item-title"},[t._v(t._s(i.title))])])])}),t._v(" "),t.json.length>0&&t.bottomLoading?a("div",{staticClass:"list-bottomLoad"},["loading"===t.bottomLoading?a("div",{staticClass:"loading"},[t._v("加载中...")]):t._e(),t._v(" "),"nothing"===t.bottomLoading?a("div",{staticClass:"nothing"},[t._v("刷完了,休息一下吧")]):t._e(),t._v(" "),"error"===t.bottomLoading?a("div",{staticClass:"error"},[t._v("出错了,刷新试试")]):t._e()]):t._e()],2)},staticRenderFns:[]};i.a=s},"86zB":function(t,i){},B8Zu:function(t,i,a){"use strict";i.a={props:{json:{type:Array,default:[]},date:{type:String,default:""},bottomLoading:{type:[Boolean,String],default:!1}},methods:{url:function(t){wx.navigateTo({url:"/pages/detail/main?id="+t.id})}}}},DEuO:function(t,i,a){"use strict";i.a={props:{loading:{type:[Boolean,String],default:!1},reload:{type:Function,default:""},nothingText:{type:String,default:"暂时没有内容"},errorText:{type:String,default:"出错了,请检查网络"}},watch:{loading:function(t){this.handleLoading(t)}},methods:{handleLoading:function(t){"loading"===t?wx.showLoading({title:"加载中",mask:!0}):wx.hideLoading()}}}},EB79:function(t,i){},IxMZ:function(t,i,a){"use strict";var s={render:function(){var t=this,i=t.$createElement,a=t._self._c||i;return t.loading?a("div",{staticClass:"pageLoading"},["nothing"===t.loading?a("div",{staticClass:"pageLoading-type nothing"},[a("icon",{staticClass:"type-icon",attrs:{type:"info",size:70}}),t._v(" "),a("div",{staticClass:"type-label"},[t._v(t._s(t.nothingText))])],1):t._e(),t._v(" "),"error"===t.loading?a("div",{staticClass:"pageLoading-type error"},[a("icon",{staticClass:"type-icon",attrs:{type:"warn",size:70}}),t._v(" "),a("div",{staticClass:"type-label"},[t._v(t._s(t.errorText))]),t._v(" "),a("button",{staticClass:"type-button",attrs:{type:"primary","hover-class":"app-button-hover",eventid:"0"},on:{click:t.reload}},[t._v("重试")])],1):t._e()]):t._e()},staticRenderFns:[]};i.a=s},KgXo:function(t,i,a){"use strict";var s=a("DEuO"),e=a("IxMZ");var n=function(t){a("PAJQ")},o=a("ybqe")(s.a,e.a,n,"data-v-771e1658",null);i.a=o.exports},M93x:function(t,i,a){"use strict";var s=a("Mw+1");var e=function(t){a("eAC6")},n=a("ybqe")(s.a,null,e,null,null);i.a=n.exports},"Mw+1":function(t,i,a){"use strict";i.a={}},NHnr:function(t,i,a){"use strict";Object.defineProperty(i,"__esModule",{value:!0});var s=a("5nAL"),e=a.n(s),n=a("M93x"),o=a("muQq"),r=(a.n(o),a("VfqU")),c=a("eWl6"),l=a("1vE0"),d=a("KgXo");e.a.component("articleList",r.a),e.a.component("commentList",c.a),e.a.component("themeList",l.a),e.a.component("my-loading",d.a),e.a.config.productionTip=!1,n.a.mpType="app",new e.a(n.a).$mount()},PAJQ:function(t,i){},Rpv1:function(t,i){},VfqU:function(t,i,a){"use strict";var s=a("B8Zu"),e=a("3cGc");var n=function(t){a("EB79")},o=a("ybqe")(s.a,e.a,n,"data-v-159a9e4c",null);i.a=o.exports},d92L:function(t,i,a){"use strict";i.a={props:{json:{type:Array,default:[]},bottomLoading:{type:[Boolean,String],default:!1}},methods:{url:function(t){wx.navigateTo({url:"/pages/theme/main?id="+t.id})}}}},e1aU:function(t,i,a){"use strict";var s={render:function(){var t=this,i=t.$createElement,a=t._self._c||i;return a("div",{staticClass:"theme-list"},[t._l(t.json,function(i,s){return a("div",{key:i.id,staticClass:"list-item",attrs:{eventid:"0-"+s},on:{click:function(a){t.url(i)}}},[a("div",{staticClass:"item-container"},[a("div",{staticClass:"item-image"},[a("img",{attrs:{src:i.thumbnail,mode:"widthFix"}})]),t._v(" "),a("div",{staticClass:"item-text"},[a("div",{staticClass:"item-title"},[t._v(t._s(i.name))]),t._v(" "),a("div",{staticClass:"item-subTitle"},[t._v(t._s(i.description))])])])])}),t._v(" "),t.bottomLoading?a("div",{staticClass:"list-bottomLoad"},["loading"===t.bottomLoading?a("div",{staticClass:"loading"},[t._v("加载中...")]):t._e(),t._v(" "),"nothing"===t.bottomLoading?a("div",{staticClass:"nothing"},[t._v("刷完了,休息一下吧")]):t._e(),t._v(" "),"error"===t.bottomLoading?a("div",{staticClass:"error"},[t._v("出错了,刷新试试")]):t._e()]):t._e()],2)},staticRenderFns:[]};i.a=s},eAC6:function(t,i){},eWl6:function(t,i,a){"use strict";var s=a("roIn"),e=a("y0VY");var n=function(t){a("86zB")},o=a("ybqe")(s.a,e.a,n,"data-v-7f4846b5",null);i.a=o.exports},muQq:function(t,i){},roIn:function(t,i,a){"use strict";i.a={props:{json:{type:Array,default:[]},bottomLoading:{type:[Boolean,String],default:!1}}}},y0VY:function(t,i,a){"use strict";var s={render:function(){var t=this,i=t.$createElement,a=t._self._c||i;return a("div",{staticClass:"comment-list"},[t._l(t.json,function(i,s){return a("div",{key:i.id,staticClass:"list-item"},[a("div",{staticClass:"item-header"},[a("div",{staticClass:"item-user"},[a("img",{staticClass:"item-avatar",attrs:{src:i.avatar}}),t._v(" "),a("div",{staticClass:"item-author"},[t._v(t._s(i.author))])]),t._v(" "),a("div",{staticClass:"item-time"},[t._v(t._s(i.time))])]),t._v(" "),a("div",{staticClass:"item-content"},[t._v(t._s(i.content))]),t._v(" "),a("div",{staticClass:"item-footer"},[a("div",{staticClass:"footer-item"},[a("div",{staticClass:"item-icon my-icon-zan"}),t._v(" "),a("div",{staticClass:"item-value "},[t._v(t._s(i.likes))])])])])}),t._v(" "),t.json.length>0&&t.bottomLoading?a("div",{staticClass:"list-bottomLoad"},["loading"===t.bottomLoading?a("div",{staticClass:"loading"},[t._v("加载中...")]):t._e(),t._v(" "),"nothing"===t.bottomLoading?a("div",{staticClass:"nothing"},[t._v("刷完了,休息一下吧")]):t._e(),t._v(" "),"error"===t.bottomLoading?a("div",{staticClass:"error"},[t._v("出错了,刷新试试")]):t._e()]):t._e()],2)},staticRenderFns:[]};i.a=s}},["NHnr"]); -------------------------------------------------------------------------------- /dist/app.json: -------------------------------------------------------------------------------- 1 | { 2 | "pages": [ 3 | "pages/index/main", 4 | "pages/detail/main", 5 | "pages/theme/main", 6 | "pages/comment/main" 7 | ], 8 | "window": { 9 | "backgroundTextStyle": "light", 10 | "navigationBarBackgroundColor": "#fff", 11 | "navigationBarTitleText": "now文章", 12 | "navigationBarTextStyle": "black" 13 | } 14 | } -------------------------------------------------------------------------------- /dist/app.wxss: -------------------------------------------------------------------------------- 1 | [class*=" my-icon-"],[class^=my-icon-]{font-family:iconfont;font-size:inherit;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}page{height:100%}.list-bottomLoad{display:flex;align-items:center;justify-content:center;height:100rpx;color:#b2b2b2;font-size:28rpx}.list-bottomLoad .error{color:#e64340}@font-face{font-family:iconfont;src:url(data:application/vnd.ms-fontobject;base64,PAsAAJQKAAABAAIAAAAAAAIABQMAAAAAAAABAJABAAAAAExQAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAABcqOkQAAAAAAAAAAAAAAAAAAAAAAABAAaQBjAG8AbgBmAG8AbgB0AAAADgBSAGUAZwB1AGwAYQByAAAAFgBWAGUAcgBzAGkAbwBuACAAMQAuADAAAAAQAGkAYwBvAG4AZgBvAG4AdAAAAAAAAAEAAAALAIAAAwAwR1NVQrD+s+0AAAE4AAAAQk9TLzI8hEsmAAABfAAAAFZjbWFwUIqL7AAAAfwAAAIQZ2x5ZnCw+kAAAAQkAAADhGhlYWQSYwZzAAAA4AAAADZoaGVhB94DiwAAALwAAAAkaG10eCgAAAAAAAHUAAAAKGxvY2EE5AQqAAAEDAAAABZtYXhwARoAQgAAARgAAAAgbmFtZT5U/n0AAAeoAAACbXBvc3SxCB5KAAAKGAAAAHsAAQAAA4D/gABcBAAAAAAABAAAAQAAAAAAAAAAAAAAAAAAAAoAAQAAAAEAAJGOygVfDzz1AAsEAAAAAADXoeEvAAAAANeh4S8AAP+5BAADXwAAAAgAAgAAAAAAAAABAAAACgA2AAYAAAAAAAIAAAAKAAoAAAD/AAAAAAAAAAEAAAAKAB4ALAABREZMVAAIAAQAAAAAAAAAAQAAAAFsaWdhAAgAAAABAAAAAQAEAAQAAAABAAgAAQAGAAAAAQAAAAAAAQQAAZAABQAIAokCzAAAAI8CiQLMAAAB6wAyAQgAAAIABQMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUGZFZABA5g7pNAOA/4AAXAOAAIAAAAABAAAAAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAQAAAAEAAAABAAAAAAAAAUAAAADAAAALAAAAAQAAAGUAAEAAAAAAI4AAwABAAAALAADAAoAAAGUAAQAYgAAABAAEAADAADmDuYX5iDmSeZ05rXpNP//AADmDuYW5iDmSeZ05rTpNP//AAAAAAAAAAAAAAAAAAAAAQAQABAAEgASABIAEgAUAAAABAAHAAgAAwAFAAYAAQAJAAIAAAEGAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwAAAAAAHwAAAAAAAAACQAA5g4AAOYOAAAABAAA5hYAAOYWAAAABwAA5hcAAOYXAAAACAAA5iAAAOYgAAAAAwAA5kkAAOZJAAAABQAA5nQAAOZ0AAAABgAA5rQAAOa0AAAAAQAA5rUAAOa1AAAACQAA6TQAAOk0AAAAAgAAAAAADgBiAHgAwgEOAVIBjgG0AcIAAAABAAAAAANuAnQAAgAACQEhAgD+kwLaAnT+GAAAAgAA//kD7AMIABQANQAAAREUBisBNSMVIyImNRE0NjEJARYVNwcGByMiJwkBBiYvASY2NwE2Mh8BNTQ2OwEyFh0BFx4BA18XEOqc6hAXBgFeAV8BgiYFCAEIBf5a/loHDwUmBQEGAbcTNhOVCwl1CAuGBgEBRf7cEBfq6hcQASQBAwEh/t8BAysuBQEEAWD+oAUCBS4GEAUBbRAQfHcICwsI+W8FEAAAAQAAAAAD+ALWAAcAAAEFFwkBFTcXA/f8ErcCxP2AZ2YC1eqvAV7+XcxmZgAEAAD/uQPfA18AEAAaACQALgAAJSInBzUuASc2JDcWBBcGBAcTIiY0NjIWFAYrASImNDYyFhQGKwEiJjQ2MhYUBiMCAS4r0VNfAQUBDcvLAQ4FBf7yy8wVHR0rHR0WzBUdHSsdHRbMFhwcLB0dFi4HfM85pGGu5gUF5q6t5wQBYR0rHR0rHR0rHR0rHR0rHR0rHQAAAgAA/8kDxAM9AAoAMQAAEyIGBxEUFjsCEQU2Jy4BJyYnIzY1NCcjLgEHDgEdAQ4BBxEhMjc2PwE2OQE2NxM2NWQQFQEWEAJqAvICEg8uHAQD0hYJAQtJLScvAVRHAe8gGxgOAQEDAlEBAd8VEP42EBYCFVAjHhccAQEBP0QsKy0vCAk8KAVLdBj93xIQGgMBBAYBawUGAAAGAAAAAAOrAdYAAAAMAA0AGQAaACYAAAE1DgEUFhcyPgE0LgEFNQ4BFBYXMj4BNC4BBTUOARQWFzI+ATQuAQNVJDAwJBgmGBgm/pMkMDAkFycXFyf+lCUwMCUXJxcXJwGAVQEwSDABFiksKRZVVQEwSDABFiksKRZVVQEwSDABFiksKRYAAAAAAQAA/9QDwAMqACMAAAUiLwEHBi4CPwEnLgE+AT8CPgEyFh8CHgIGDwEXFg4BAvAPD9DSECQeDgMrpA4JCxsU5WYJHiUgB2fkExsMCQ2lKQQPHSsIaGgJAxYiE+CZDiQkGAIq0BETExHQKAMYJCQNm+AUIRgAAAAAAQAAAAADqwMAABEAABM+ATceARc+ATceARcGAAcmAFUDfV1BbCEcakFegwMU/rdOTv63AhViggcBRDs7RAEDhWP8/ukCAwEaAAAAAAEAAAAAA24CdAACAAAlASECAAFt/SaMAegAAAAAABIA3gABAAAAAAAAABUAAAABAAAAAAABAAgAFQABAAAAAAACAAcAHQABAAAAAAADAAgAJAABAAAAAAAEAAgALAABAAAAAAAFAAsANAABAAAAAAAGAAgAPwABAAAAAAAKACsARwABAAAAAAALABMAcgADAAEECQAAACoAhQADAAEECQABABAArwADAAEECQACAA4AvwADAAEECQADABAAzQADAAEECQAEABAA3QADAAEECQAFABYA7QADAAEECQAGABABAwADAAEECQAKAFYBEwADAAEECQALACYBaQpDcmVhdGVkIGJ5IGljb25mb250Cmljb25mb250UmVndWxhcmljb25mb250aWNvbmZvbnRWZXJzaW9uIDEuMGljb25mb250R2VuZXJhdGVkIGJ5IHN2ZzJ0dGYgZnJvbSBGb250ZWxsbyBwcm9qZWN0Lmh0dHA6Ly9mb250ZWxsby5jb20ACgBDAHIAZQBhAHQAZQBkACAAYgB5ACAAaQBjAG8AbgBmAG8AbgB0AAoAaQBjAG8AbgBmAG8AbgB0AFIAZQBnAHUAbABhAHIAaQBjAG8AbgBmAG8AbgB0AGkAYwBvAG4AZgBvAG4AdABWAGUAcgBzAGkAbwBuACAAMQAuADAAaQBjAG8AbgBmAG8AbgB0AEcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAAcwB2AGcAMgB0AHQAZgAgAGYAcgBvAG0AIABGAG8AbgB0AGUAbABsAG8AIABwAHIAbwBqAGUAYwB0AC4AaAB0AHQAcAA6AC8ALwBmAG8AbgB0AGUAbABsAG8ALgBjAG8AbQAAAAACAAAAAAAAAAoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAoBAgEDAQQBBQEGAQcBCAEJAQoBCwAHdm90ZS11cARob21lBXNoYXJlCGNvbW1lbnRzA3phbgRtb3JlB2NvbGxlY3QFdGhhbmsOdm90ZS1kb3duLWNvcHkAAAA=);src:url(data:application/vnd.ms-fontobject;base64,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#iefix) format("embedded-opentype"),url("data:application/x-font-woff;charset=utf-8;base64,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") format("woff"),url(data:font/ttf;base64,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) format("truetype"),url(data:image/svg+xml;base64,<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
<!--
2013-9-30: Created.
-->
<svg>
<metadata>
Created by iconfont
</metadata>
<defs>

<font id="iconfont" horiz-adv-x="1024" >
  <font-face
    font-family="iconfont"
    font-weight="500"
    font-stretch="normal"
    units-per-em="1024"
    ascent="896"
    descent="-128"
  />
    <missing-glyph />
    
    <glyph glyph-name="vote-up" unicode="&#59060;" d="M511.997952 627.9742679999999L146.975708 140.02573199999995l730.048584 0L511.997952 627.9742679999999"  horiz-adv-x="1024" />

    
    <glyph glyph-name="home" unicode="&#59700;" d="M863.08571413 325.48571413l0-292.57142826q0-15.8476192-11.58095253-27.42857174t-27.42857173-11.58095253l-234.0571424 0 0 234.0571424-156.03809494 0 0-234.0571424-234.0571424 0q-15.8476192 0-27.42857173 11.58095253t-11.58095253 27.42857174l0 292.57142826q0 0.60952427 3.0476192 1.82857174t3.0476192 1.82857173l350.47619093 288.91428587 350.47619093-288.91428587q0.60952427-1.21904747 0.60952427-3.6571424z m135.92380907 42.0571424l-37.79047573-45.1047616q-4.87619093-5.48571413-12.8-6.7047616l-1.82857174 0q-7.92380907 0-12.8 4.26666667l-421.79047573 351.6952384-421.79047573-351.6952384q-7.31428587-4.87619093-14.62857174-4.26666667-7.92380907 1.21904747-12.8 6.7047616l-37.79047573 45.1047616q-4.87619093 6.0952384-4.26666667 14.32380907t6.7047616 13.1047616l438.2476192 365.1047616q19.5047616 15.8476192 46.32380907 15.8476192t46.32380907-15.8476192l148.72380906-124.3428576 0 118.8571424q0 8.53333333 5.48571414 14.01904747t14.01904746 5.48571413l117.02857174 0q8.53333333 0 14.01904746-5.48571413t5.48571414-14.01904747l0-248.68571413 133.48571413-110.93333334q6.0952384-4.87619093 6.7047616-13.1047616t-4.26666667-14.32380906z"  horiz-adv-x="1024" />

    
    <glyph glyph-name="share" unicode="&#58912;" d="M1015.466667 725.333333L8.533333 490.666667 192 315.733333 900.266667 665.6 260.266667 247.46666700000003 260.266667 42.66666699999996 362.666667 145.06666700000005 465.066667 42.66666699999996Z"  horiz-adv-x="1024" />

    
    <glyph glyph-name="comments" unicode="&#58894;" d="M513.216 45.888000000000034c-30.528 0-60.224 2.88-89.216 7.488l-209.28-124.032 0 206.528c-109.056 74.88-179.136 189.632-179.136 318.528 0 225.472 213.888 408.32 477.632 408.32 263.808 0 477.696-182.848 477.696-408.32C990.912 228.86400000000003 777.024 45.888000000000034 513.216 45.888000000000034L513.216 45.888000000000034zM717.44 398.784c-28.16 0-51.072 22.656-51.072 50.688 0 28.032 22.848 50.688 51.072 50.688 28.096 0 51.008-22.656 51.008-50.688C768.448 421.504 745.536 398.784 717.44 398.784L717.44 398.784zM513.216 398.784c-28.16 0-50.944 22.656-50.944 50.688 0 28.032 22.784 50.688 50.944 50.688 28.224 0 51.072-22.656 51.072-50.688C564.288 421.504 541.44 398.784 513.216 398.784L513.216 398.784zM309.12 398.784c-28.16 0-51.008 22.656-51.008 50.688 0 28.032 22.848 50.688 51.008 50.688S360.128 477.44 360.128 449.472C360.128 421.504 337.344 398.784 309.12 398.784L309.12 398.784z"  horiz-adv-x="1024" />

    
    <glyph glyph-name="zan" unicode="&#58953;" d="M99.962689 479.362928c-20.877493 0.041956-37.835723-16.851806-37.870516-37.7293 0-0.119727 0-0.232291 0-0.352017L62.092174-16.260080000000016c-0.041956-20.793582 16.724917-37.715997 37.518498-37.870516 0.914836 0 1.689479 0.493234 2.604314 0.493234l105.938797 0L208.153784 479.293343 101.510952 479.293343C100.948133 479.081519 100.455923 479.362928 99.962689 479.362928L99.962689 479.362928zM961.689862 398.625092c1.422396 22.800285-4.152577 45.493124-15.978926 65.041342-19.09694 31.141254-52.405557 50.766221-88.903819 52.370765-2.288113 0.732687-4.64581 1.224898-7.039323 1.478677L640.214127 517.5158759999999c14.690584 42.333154 22.187325 86.827531 22.172999 131.630946-0.070608 29.28907-3.302209 58.480926-9.643638 87.074148l-0.633427 0c-12.663414 58.755172-70.560032 96.111988-129.315204 83.442434-50.865481-10.959609-86.84902-56.405661-85.87074-108.430548 0-1.90028 0.493234-3.730974 0.562818-5.631254-0.542352-97.758488-63.436798-184.255491-156.268066-214.903511l0-544.404014 494.426763 0 0 0c21.088294-0.119727 41.756009 5.898337 59.480696 17.316387 15.922644 10.587126 28.811186 25.143657 37.377282 42.234917 0.704035 0.914836 1.196245 1.90028 1.830695 2.885723 0.633427 0.985444 0.352017 0.493234 0.493234 0.774643l0 0c2.25946 3.230578 3.991917 6.792707 5.13802 10.558473l81.020268 362.936009c0.753153 3.631714 0.971118 7.355525 0.633427 11.051707 0 0.49221 0 0.985444 0 1.478677C961.619254 396.020778 961.830055 397.56904 961.689862 398.625092L961.689862 398.625092z"  horiz-adv-x="1024" />

    
    <glyph glyph-name="more" unicode="&#58996;" d="M853.333333 384m0 85.333333a85.333333 85.333333 0 1 1 0-170.666666 85.333333 85.333333 0 1 1 0 170.666666ZM512 384m0 85.333333a85.333333 85.333333 0 1 1 0-170.666666 85.333333 85.333333 0 1 1 0 170.666666ZM170.666667 384m0 85.333333a85.333333 85.333333 0 1 1 0-170.666666 85.333333 85.333333 0 1 1 0 170.666666Z"  horiz-adv-x="1024" />

    
    <glyph glyph-name="collect" unicode="&#58902;" d="M752-43.200000000000045c-9.6 0-20.8 3.2-30.4 8l-208 104-209.6-104c-20.8-11.2-48-9.6-67.2 4.8-19.2 14.4-30.4 40-25.6 64l43.2 224L89.6 411.2C72 428.8 65.6 456 72 478.4c8 24 27.2 41.6 52.8 44.8l228.8 41.6 102.4 208c11.2 22.4 33.6 36.8 57.6 36.8s48-14.4 57.6-36.8l102.4-208 228.8-40c24-3.2 44.8-20.8 51.2-44.8 8-24 1.6-49.6-16-67.2L772.8 257.6l41.6-224c4.8-25.6-6.4-49.6-25.6-64-9.6-8-22.4-12.8-36.8-12.8z"  horiz-adv-x="1024" />

    
    <glyph glyph-name="thank" unicode="&#58903;" d="M85.333333 533.333333c0 128 99.555556 227.555556 220.444445 234.666667 85.333333 0 163.555556-49.777778 206.222222-128 35.555556 78.222222 113.777778 128 199.111111 128 120.888889 0 227.555556-106.666667 227.555556-234.666667 0-334.222222-348.444444-533.333333-426.666667-533.333333s-426.666667 206.222222-426.666667 533.333333z"  horiz-adv-x="1024" />

    
    <glyph glyph-name="vote-down-copy" unicode="&#59061;" d="M512.002048 140.02573199999995L877.024292 627.9742679999999l-730.048584 0L512.002048 140.02573199999995"  horiz-adv-x="1024" />

    


  </font>
</defs></svg>
#iconfont) format("svg")}.iconfont{font-family:iconfont!important;font-size:32rpx;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.my-icon-vote-up:before{content:"\E6B4"}.my-icon-home:before{content:"\E934"}.my-icon-share:before{content:"\E620"}.my-icon-comments:before{content:"\E60E"}.my-icon-zan:before{content:"\E649"}.my-icon-more:before{content:"\E674"}.my-icon-collect:before{content:"\E616"}.my-icon-thank:before{content:"\E617"}.my-icon-vote-down-copy:before{content:"\E6B5"}.article-list.data-v-159a9e4c{box-sizing:border-box}.article-list .list-date.data-v-159a9e4c{display:flex;align-items:center;justify-content:center;color:#fff;font-size:28rpx;letter-spacing:2rpx;width:40%;height:56rpx;margin-top:24rpx;border-radius:100rpx;background-color:#0084ff}.article-list .list-item.data-v-159a9e4c{box-sizing:border-box;position:relative;padding:24rpx 0;margin:0 32rpx;border-bottom:2rpx solid #f4f4f4}.article-list .list-item .item-container .item-title.data-v-159a9e4c{color:#000;font-size:34rpx;-webkit-line-clamp:3;text-overflow:ellipsis;overflow:hidden}.article-list .list-item .item-container.images.data-v-159a9e4c{display:flex;align-items:center}.article-list .list-item .item-container.images .item-title.data-v-159a9e4c{width:67%;padding-right:30rpx}.article-list .list-item .item-container.images .item-images.data-v-159a9e4c{width:33%;height:156rpx;border-radius:10rpx;overflow:hidden}.article-list .list-item .item-container.images .item-images ._img.data-v-159a9e4c{display:block;width:100%}.article-list .list-item .item-container.text.data-v-159a9e4c{width:100%}.comment-list.data-v-7f4846b5{position:relative;width:100%}.comment-list .list-item.data-v-7f4846b5{box-sizing:border-box;position:relative;color:#353535;font-size:30rpx;padding:24rpx 0;margin:0 40rpx;border-bottom:2rpx solid #f4f4f4}.comment-list .list-item .item-header.data-v-7f4846b5{display:flex;align-items:center;margin-bottom:16rpx}.comment-list .list-item .item-header .item-user.data-v-7f4846b5{display:flex;align-items:center}.comment-list .list-item .item-header .item-user .item-avatar.data-v-7f4846b5{width:48rpx;height:48rpx;margin-right:16rpx;border-radius:100%;overflow:hidden}.comment-list .list-item .item-header .item-user .item-avatar ._img.data-v-7f4846b5{display:block;width:100%;height:100%}.comment-list .list-item .item-header .item-time.data-v-7f4846b5{color:#8590a6;font-size:28rpx;margin-left:auto}.comment-list .list-item .item-content.data-v-7f4846b5{margin-bottom:16rpx}.comment-list .list-item .item-footer.data-v-7f4846b5{display:flex;align-items:center}.comment-list .list-item .item-footer .footer-item.data-v-7f4846b5{display:flex;align-items:center;justify-content:center;color:#8590a6;font-size:28rpx;line-height:1}.comment-list .list-item .item-footer .footer-item .item-icon.data-v-7f4846b5{margin-right:10rpx}.theme-list .list-item.data-v-56c0841f{box-sizing:border-box;position:relative;margin:30rpx 32rpx;border:2rpx solid #ebeef5;border-radius:10rpx;box-shadow:0 4rpx 24rpx 0 rgba(0,0,0,.1);background-color:#fff;overflow:hidden}.theme-list .list-item .item-container.data-v-56c0841f{box-sizing:border-box;display:flex;align-items:center;width:100%;padding:30rpx 24rpx}.theme-list .list-item .item-container .item-image.data-v-56c0841f{width:33%;height:156rpx;border-radius:10rpx;overflow:hidden;background-color:#ddd}.theme-list .list-item .item-container .item-image ._img.data-v-56c0841f{display:block;width:100%}.theme-list .list-item .item-container .item-text.data-v-56c0841f{width:67%;padding-left:30rpx}.theme-list .list-item .item-container .item-text .item-title.data-v-56c0841f{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;color:#000;font-size:34rpx}.theme-list .list-item .item-container .item-text .item-subTitle.data-v-56c0841f{color:#000;font-size:28rpx}.pageLoading.data-v-771e1658{position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;color:#888;font-size:36rpx;background:#fff;display:flex;justify-content:center}.pageLoading .pageLoading-type.data-v-771e1658{box-sizing:border-box;width:100%;text-align:center;padding:0 32rpx;margin-top:30%}.pageLoading .pageLoading-type .type-label.data-v-771e1658{margin-top:40rpx}.pageLoading .pageLoading-type .type-button.data-v-771e1658{margin-top:40rpx;background-color:#0084ff}.pageLoading .pageLoading-type.error .app-button-hover.data-v-771e1658{background-color:rgba(0,132,255,.2);opacity:.7} -------------------------------------------------------------------------------- /dist/common/manifest.js: -------------------------------------------------------------------------------- 1 | !function(r){var e=global.webpackJsonp;global.webpackJsonp=function(n,u,c){for(var l,f,a,p=0,i=[];p{{date}} {{item.title}} {{item.title}} 加载中... 刷完了,休息一下吧 出错了,刷新试试 -------------------------------------------------------------------------------- /dist/components/commentList.vue.wxml: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /dist/components/loading.vue.wxml: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /dist/components/slots.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | -------------------------------------------------------------------------------- /dist/components/themeList.vue.wxml: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /dist/pages/comment/index.vue.wxml: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /dist/pages/comment/main.js: -------------------------------------------------------------------------------- 1 | require("../../common/manifest.js"); 2 | require("../../common/vendor.js"); 3 | global.webpackJsonp([5],{CcDX:function(t,n,o){"use strict";var i={render:function(){var t=this.$createElement,n=this._self._c||t;return n("div",{attrs:{id:"comment"}},[n("scroll-view",{style:{height:this.winHeight+"px"},attrs:{"scroll-y":"","enable-back-to-top":!0,eventid:"0"},on:{scrolltolower:this.getShortCommentMore}},[n("comment-list",{attrs:{json:this.comments,bottomLoading:this.bottomLoading,mpcomid:"0"}})],1),this._v(" "),n("my-loading",{attrs:{loading:this.loading,reload:this.getShortComment,mpcomid:"1"}})],1)},staticRenderFns:[]};n.a=i},a1pF:function(t,n,o){"use strict";Object.defineProperty(n,"__esModule",{value:!0});var i=o("5nAL"),e=o.n(i),s=o("e73g");new e.a(s.a).$mount()},e73g:function(t,n,o){"use strict";var i=o("jMTm"),e=o("CcDX");var s=function(t){o("zanE")},m=o("ybqe")(i.a,e.a,s,null,null);n.a=m.exports},jMTm:function(t,n,o){"use strict";var i=o("Gu7T"),e=o.n(i),s=o("gyMJ"),m=o("0xDb");n.a={data:function(){return{winHeight:0,id:"",comments:[],loading:!1,bottomLoading:!0}},mounted:function(){this.id=this.$root.$mp.query.id,this.getSystemInfo(),this.getShortComment()},methods:{getShortComment:function(){var t=this;this.loading="loading",Object(s.f)(this.id).then(function(n){n&&n.comments.length>0?(t.loading=!1,n.comments.forEach(function(t){t.time=Object(m.c)(t.time)}),t.comments=n.comments):t.loading="nothing"}).catch(function(){t.loading="error"})},getShortCommentMore:function(){var t=this;if("nothing"!==this.bottomLoading&&"error"!==this.bottomLoading){this.bottomLoading="loading";var n=this.comments[this.comments.length-1].id;Object(s.g)(this.id,n).then(function(n){var o;n&&n.comments.length>0?(t.bottomLoading=!0,n.comments.forEach(function(t){t.time=Object(m.c)(t.time)}),(o=t.comments).push.apply(o,e()(n.comments))):t.bottomLoading="nothing"}).catch(function(){t.bottomLoading="error"})}},getSystemInfo:function(){var t=this;wx.getSystemInfo({success:function(n){t.winHeight=n.windowHeight}})}}}},zanE:function(t,n){}},["a1pF"]); -------------------------------------------------------------------------------- /dist/pages/comment/main.json: -------------------------------------------------------------------------------- 1 | { 2 | "navigationBarTitleText": "评论" 3 | } 4 | -------------------------------------------------------------------------------- /dist/pages/comment/main.wxml: -------------------------------------------------------------------------------- 1 |