vue的探索之路(一)

前言:这次的App项目是由native+H5组合而成,整个App分为2个模块,我负责的是商城首页到生成订单的一系列页面以及业务代码,在这里总结一下遇到的问题。第一次写笔记,多多见谅。

打包工具

项目采用webpack进行打包,虽然之前有过一些基础的接触,但是这次还是第一次自己尝试的去配置,稍微补了一下webpack的内容。

//webpack.config.js
module.exports = {
    entry: {
        ProductDetails:"./src/js/ProductDetails.js",
        Orderdetail:"./src/js/Orderdetail.js",
        Logistics:"./src/js/Logistics.js",
        Index:"./src/js/Index.js",
        ...
    },
    output: {
        path: './dist',
        filename: '[name].js'
    },
     resolve: {
        alias: {
            'vue': 'vue/dist/vue.js',
        }
    }, 
    module: {
        loaders: [
            {
                test: /\.js$/,
                loader: 'babel',
                exclude: /node_modules/
            },
            {
                test: /\.vue$/,
                loader: 'vue'
            },
            {
                test: /\.css$/,
                loader: 'style-loader!css-loader!'
            },
            {
                test: /\.scss$/,
                exclude: /node_modules/,
                loader: 'style-loader!css-loader!sass-loader'
            },
            {
                test: /\.(png|jpg|gif|svg)$/,
                loader: 'url' 
            }
            
        ]
    },
    
}

入口

entry :配置起始文件的路径,它可以是数组,对象,字符串。在这里我采用了多页面入口的方式。

输出

output: path: 配置最终打包完成后的路径所在;filename:最终打包后文件的名称,由于是多页面入口文件,这里为了方便使用[name].js,这样最终打包出来的文件名称跟入口文件名称一致。

加载器

module(loaders):
test:注意是正则表达式,不要加引号,匹配要处理的文件

loader:要使用的loader,"-loader"可以省略

include: 把要处理的目录包括进来

exclude:不需要去处理的目录。


与native的交互

  • 目前是通过自定义协议的方式,也就是URL,协商一个通用的协议比如app.owen://?pushcode=1 ,前端通过location.href,而native则是通过截取这段URL,获取里面的参数进行处理。

难点一.

模仿淘宝商品详情,虽然不要求完全一样但是功能基本要一致。难点就是在商品属性选择后价格,库存,图片都要改变,到这首先想到的就是Vue中的watch.然后就是每种分类的点击效果,不冲突,不重复。

demo1.png

demo2.png

这里我想了很久该怎么做才能做到点击效果的同时又能使用watch监控,实现动态。经过不断的尝试我终于找到了方法,通过深入响应式原理了解,只有在data属性上的js对象都被会vue遍历再通过Object.definePropery将全部属性转换getter/setter,可以通过console.log()查看,它们在内部行了追踪依赖,才能实现响应。

在这里有个重点,Vue 不允许在已经创建的实例上动态添加新的根级响应式属性,也就是说我们只能动态添加在已存在的根级属性中,我在Vue创建了根级属性iscur

    data: {
        iscur: {},//当前的商品子属性attrid
    }  
    

可以通过this.$set(this.iscur,'b',2),但是如果新添加的新属性在改变后并不会触发更新怎么办,这里是采用this.someObject = Object.assign({}, this.someObject, { a: 1, b: 2 }),创建一个新的对象,让它包含原对象的属性和新的属性。

言归正传,通过请求获取分类数据,这里我通过遍历父分类,给iscur动态添加属性,

            this.arrts.forEach( (val, index)=> {              
                    var attrsId = {
                        //设置子分类attrid
                        ['type' + index]: ""
                    }
                    ....
                    this.iscur = Object.assign({}, this.iscur, attrsId) //实现data响应
                    ....              
                })

可以看到iscur 中的属性,


demo3.png

在看看HTML处:

//父分类
<div class="attr" v-for="(attr,findex) in arrts">
   <h1 >{{attr.attrname}}</h1>
   <ul :id="attr.attrid">
          //子分类
          <li  v-for="(item,index) in attr.attrValueList" 
           :class="{active:iscur['type'+findex]==item.attrid}"         
           v-on:click="actives($event,findex,item.attrid)"                   
          >{{item.attrname}}</li>                   
   </ul>
</div>

首先分类信息会有两次遍历,首先遍历出父分类,再遍历子分类,其中:class="{active:iscur['type'+findex]==item.attrid}是判断当前父分类下选中的是哪个子分类id。v-on:click="actives($event,findex,item.attrid)点击子分类时将父分类的id和子分类的id传入

 actives: function (e, findex, attrid) {   
            this.iscur['type' + findex] = attrid;
        }

最后使用watch监控iscur对象,在每次点击后,iscur就会发生改变,从而执行handler,
在其中执行对比sku,更换价格,图片,以及库存。

iscur: {
            /*
            监控 iscur 对象
            当iscur中属性发生变化时,我们获取iscur中每个属性的value值,再与价格表中的数据进行对比,提取出相同项的数据
            */

            handler: function (val) {

                // do  something 
            },
            // 深度观察
            deep: true
        },

难点二.

这种类分页:

demo5.png

最开始做的时候也最简单,上面部分横向导航栏,下面展示商品,每次点击分类时候去请求相应的数据,替换掉展示商品部分的数据,这样的结果就是出现重复请求数据,体验也差。之后想试着优化这部分,看了主流app类似这种分类页效果,就是点击子分类,如果是第一次则加载数据,否则就显示数据,再次点击分类的时候刷新。
思路:首先我在data中设置一个属性productlist专门用来存放数据,默认值设置为一个空数组 ,在子分类成功后执行setModels方法

setModels: function (datas) { 
            /**
             * 初始化productlist的数据结构
             * 根据分类数据遍历后分别添加obj,用来存放数据
             */

            datas.forEach((value, index) => {
                var obj = {
                    brandid: value.brandid,
                    list: []
                }
                this.productlist.push(obj)
            })
        },

通过这个方法,productlist拥有了跟分类相同个数对象,之后每次点击子分类后去请求商品列表,然后遍历每个数据push到相应obj的list数组中,这样就保存了数据。当然点击时候还需要一个方法去判断什么时候去请求。

 cacheData: function (index,brandid) {
            /**
             * 通过index知道分类的索引号,获取数据
             * 如果list的长度为0,代表无数据,则去请求数据
             */   
            var indexdata=this.productlist[index]
            if(indexdata.list.length==0){
                this.getlistdata(brandid)
            }else{
                return false
            }
            
        },

Tips

this.$nextTick(function(){
//dom更新
})

这个方法通常是我们需要运用到dom时候调用的,比如swiper,js 在获取图片数据后,实例化swiper必须在该回调函数内执行才有效。获取一些其他第三方插件需要操作dom节点,获取边距等都需要在回调函数内执行。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容