前天完成了一个新组件的开发,做的过程也是各种遇到问题,彻底弄懂了slot,巩固了一些flex布局和jquery的知识,比起自己第一次做组件开发,现在已经是能够下手做,遇到问题解决问题,还算有进步。

但是昨天写博客的时候,就在我快写完的时候,chrome崩溃了。。。我也崩溃了。。。写的东西全没有了!!!我还是继续重新码字吧。。。崩溃。。。

做的这个组件给它起个什么名字比较合理我想了半天也没想出来。。。

需求是这样的:

  • 由两部分组成,上面是导航条,下面每一块显示内容。如下图。
  • 导航条固定在顶部
  • 点击导航里的每一个标签,该标签高亮,该标签相应的div自动跳到内容部分第一栏的位置(这里最后一栏无法跳到第一栏,因为要撑开整个页面)
  • 滑动下面的内容,滑到哪个div对应的navs的标签高亮

核心代码写在下面~供参考哦

html插入nav-list模板:

<div id="main">
<nav-list :navs="navs" :contents="contents">
<div v-for="con in contents" :class="'con_' + con.en_name" :slot="'con_' + con.en_name">{{ con.text }}</div> // :class要写在这里,而不要写在<slot>上
</nav-list>
</div>

子组件模板:

这里重点是如何使用slot,并且如何将navs的每一个标签和下面的div对应联系起来!

<template>
<div class="navList">
<div class="nav">
<div v-for="nav in navs" v-bind:class="{ active: cur == nav.en_name }" v-on:click="changeNav(nav.en_name)">{{ nav.name }}</div>
</div>
<div class="list">
<slot v-for="nav in navs" :name="'con_' + nav.en_name"></slot>
</div>
</div>
</template>

子模板的操作代码:

return{
props: {
navs: {
type: Array
, default: function(){
return {}
}
}
, contents: {
type: Array
, default: function(){
return {}
}
} }
, data: function(){
return {
cur: this.navs[0].en_name // 可以在data中这样定义初始值, 这里是将cur的初始值设定为navs的第一个en_name值
}
}
, methods: {
changeNav: function(index){ // 点击任意标签,调用该事件,改变其相应div的位置,即使整个页面向上滑动一定的距离。
this.cur = index
var pos = $(".con_" + index).position().top
var pos2 = $('.navList').position().top // 这个是整个组件距离页面顶端的距离。
$(window).scrollTop(pos+pos2)
}
, scroll: function(){ // scroll()这个事件是div滑动停止时触发的,事件内部定义了:如何确定是哪个div在第一个显示位置,从而找到相应的navs的标签
var _this = this
$(window).on('scrollStop', function(event) {
for( attr in _this.navs ){ var curPos = $(".con_" + _this.navs[attr].en_name).offset().top
var curPos2 = curPos + $(".con_" + _this.navs[attr].en_name).height()
if( curPos <= $(window).scrollTop() + $(".nav").height() && $(window).scrollTop() + $(".nav").height() <= curPos2){
_this.cur = _this.navs[attr].en_name
}else if($(window).scrollTop() < $('.navList').offset().top){
_this.cur = _this.navs[0].en_name
}
} })
}
}
, mounted: function(){
this.scroll() this.$nextTick(function(){
$('.nav').sticky({ // 这个也是直接写好的置于顶部的组件,我也是直接将它用在nav上
infinity: true
})
})
}
}

  以上是所有vue组件代码,下面创建一个父实例的js文件:

var sticky = require('core/m/sticky_vue')

var vm = new Vue({
el: "#main"
,components: {
navList: require('navList.vue')
}
, data: function(){
return {
navs: [{ name: '美妆', en_name: 'makeup' }
, { name: '时尚', en_name: 'fashion' }
, { name: '鞋履', en_name: 'shoes' }
, { name: '大牌', en_name: 'board'}
, { name: '潮服', en_name: 'clothes'}
]
, contents: [
{ en_name: 'makeup', text: '美妆美妆'}
, { en_name: 'fashion', text: '时尚在哪里时尚在哪里'}
, { en_name: 'shoes', text: '鞋鞋鞋子'}
, { en_name: 'board', text: '大牌驾到'}
, { en_name: 'clothes', text: '服饰!!!'}
]
}
} })

  以上就是所有的代码了~在整个过程中遇到的问题都是基础知识不扎实,还有vue的使用不很流畅。大致有以下几点:

  1. jQuery的offset().top和position().top区分使用,offsetTop得到的是undefined,$(window).scrollTop()可以获取页面的整个垂直的滚动高度,$(window).scrollTop(值)则是设置滚动高度。在做的过程中,对于div要滚动多少、要获取的是div距页面的高还是句定位父级的高、页面要滚动多少、是否要包含nav的高度等等都是需要考虑的问题,所以这一部分自己还是理解的不到位,所以滚动的高度具体的调节都是通过实验的方式得到的。
  2. scroll()事件何时触发是我一开始不太明白的,比如changeNav(){}我定义在methods中,然后使用v-on:click="changeNav()"调用即可,那么scroll()这类事件应该放在哪里触发呢?在vue中我们将这些事件定义在methods中,然后在mounted或是created中调用即可!

  

基于vue的新组件开发的更多相关文章

  1. 基于Vue的WebApp项目开发(二)

    利用webpack解析和打包.vue组件页面 相关知识: vue项目中的每个页面其实都是一个.vue的文件,这种文件,Vue称之为组件页面,必须借助于webpack的vue-loader才能运行,所以 ...

  2. 基于vue项目的组件中导入mui框架初始化滑动等效果时需移除严格模式的问题

    基于vue项目的组件中导入mui框架初始化滑动等效果时,控制台报错:Uncaught TypeError: 'caller', 'callee', and 'arguments' properties ...

  3. vue拖拽组件开发

    vue拖拽组件开发 创建临时vue项目 先查看node和npm版本,怎么安装就不多多bb了 再安装vue-cli npm install vue-cli -g //全局安装 vue-cli 检测是否安 ...

  4. 基于Vue的npm组件库

    前言(*❦ω❦) 思维导图可能有点高糊,有点太大了,项目和导图文件放到github或giteee上,这个思维导图也是我文章的架构,思维导图是用FeHelper插件生成的,这个是一款开源chrome插件 ...

  5. 【技术博客】基于vue的前端快速开发(工具篇)

    一.Vue教程 vue.js是一套构建用户界面的渐进式框架.vue采用自底向上增量开发的设计.vue的核心库只关心视图层,非常容易学习,非常容易与其它库和已有项目整合.vue完全有能力驱动采用单文件组 ...

  6. 基于Vue封装分页组件

    使用Vue做双向绑定的时候,可能经常会用到分页功能 接下来我们来封装一个分页组件 先定义样式文件 pagination.css ul, li { margin: 0px; padding: 0px;} ...

  7. 基于Vue的WebApp项目开发(四)

    实现新闻咨询页面 目录结构 步骤一:创建newslist.vue文件 <template> <div id="tml"> <!--使用mui框架,实现 ...

  8. tornado 基于MongoDB存储 session组件开发

    1.开发伊始 根据源码中RequestHandler类中发现__init__函数中会调用自身initialize函数,此函数中为pass,即可以围绕initialize开发一系列的组件 2.开发实现 ...

  9. 基于Vue的WebApp项目开发(六)

    实现商品购买列表页面 步骤一:新建goodslist.vue文件 <template> <div id="tml"> <!--利用mui中的图文表格组 ...

随机推荐

  1. JavaScript引擎LHS查找和RHS查找

    要想真正理解Javascript脚本中每一句代码的执行过程,需要弄清楚几个基本概念:1.引擎,从头到尾负责整个 JavaScript 程序的编译及执行过程.2.编译器,引擎的好朋友之一,负责语法分析及 ...

  2. CSS3学习之分享下transition属性

    最近在网上看到很多transition写的效果,借鉴http://www.w3school.com.cn分享下代码, 1.语法:transition: property duration timing ...

  3. <c:forEach>循环list,一个表格两列数据

    参考: http://zhidao.baidu.com/link?url=apG5dUmW7RjB5eOYKSWOWdKd7nxFpkDO4n3i8R6MWYKl7E2JC1OCtPILF4G4EUO ...

  4. C#中获取当前时间:System.DateTime.Now.ToString()用法

    //2008年4月24日 System.DateTime.Now.ToString("D"); //2008-4-24 System.DateTime.Now.ToString(& ...

  5. shell 转义字符的写法

    在链接中,往往会遇到含有‘&'字符的情形,需要转义方能使用. 以下是它的写法样例,错误的写法勿要再犯!! 链接样例: http://my.example.cn/show/details/htd ...

  6. DNS bind子域授权安装

    失败经验:rhel 6.x bind 9.8,两台做子域授权,最后失败.原因不详. 改用rhel 5.5, bind 9.3,同样的配置,就成功了.具体记录一下9.3的配置. 安装:采用安装RHEL时 ...

  7. spring事务详解(转载+高亮)

    spring提供的事务管理可以分为两类:编程式的和声明式的.编程式的,比较灵活,但是代码量大,存在重复的代码比较多:声明式的比编程式的更灵活.编程式主要使用transactionTemplate.省略 ...

  8. Const(常量)与readonly(只读)的区别

    const与readonly定义的值都不能更改,但它们到底有哪些异同点呢? Const ² Const是常量的意思,其定义的变量只能读取不能更改,且只能在定义时初始化,不能在构造函数与其它属性与方法中 ...

  9. nginx(一)

    crul新浪微博的时候发现对面用的是nginx服务器,在虎扑足球(挺好的足球论坛)讨论世界杯也发现他们也用这nginx,联想到阿里的tengine也是基于nginx的,觉得有了解一下nginx的必要了 ...

  10. 7月10日——[HouseStark] 扬帆起航--第一次会议

    本次会议为小组成员第一次会议 内容:每个成员提出一个及以上的项目及内容,成员内部商议并投票决定要做的项目 会议时长:90分钟 地点:电三楼8楼816室 成员 项目 讨论结果 崔文祥 高校就业信息汇总网 ...