vue做文章发布与展示怎么确定图片显示的位置?

这一段时间一直在做一个博客项目 ,找了一圈发现没有特别满足自己需求的目录组件,所以决定自己动手,完成一个满足以下预期目标的目录组件:

  • 自动高亮选中当前正在阅读的章节
  • 自动展开当前正在阅读的章节的子标题,并隐藏其他章节的子标题

完成后的目录组件如下图左侧所示:

由于标题之间有父子的关系,所以我们应该用树数据结构来解决这个问题。我们遍历文章容器中的所有标签,如果遇到 <h1><h2> 这类标签,就创建一个节点,将其放到列表中,之后使用 v-for 指令来生成目录就行了。下面分析一下每个节点需要有哪些属性。

一个树的节点,应该具有的属性包括:父节点的指针 parent、子节点的指针列表 children,因为一个节点代表一个标题,所以还要包含:标题的 ID号 id(用于 v-forkey),标题名 name(添加了标题的序号)、原始标题名 rawName 和标题的可见性 isVisible,当我们点击标题时,应该滚动到标题的位置,所以还要有 scrollTop 属性。在我们遍历文章容器中的所有标签时,需要判断当前遇到的标签和上一个标签之间的父子关系,所以要有一个 level 属性代表每一个节点的等级。下面是具体实现代码:

// 监听滚动事件并更新样式 // 设置子节点的可见性 // 滚动到指定的位置
}

这是一个自动轮播播放图,来让我们看一下代码:(用到的主要是对定时器和css样式的调节)

<!-- 判断文字左边的图标,当是选中状态的时候,将其变为蓝色 --> <!-- 判断文字是否是选中状态,然后相应的改变选中和没有被选中的样式 --> <!-- 右边部分对应的图片,第一部分对应的是第一张图片,第二部分对应的是第二张图片,第三部分对应的是第三张图片-->

先来看一下created和data里面的数据逻辑

// 每次进入界面时,先清除之前的所有定时器,然后启动新的定时器 //当程序进来的时候,打开定时器,令起自动轮播

然后再看一下methods里面的方法

//当鼠标悬停的时候关闭定时器 当鼠标离开的时候打开定时器

接下来,在页面销毁之前我们要把定时器给关闭 在beforeDestroy里面操作

// 在页面注销前,将定时器给关闭
/*文字正常的样式*/ /*文字被选中之后的样式,放大0.3倍*/
}

把界面改了一下,开始实际填充功能。

它把命令组织成一组“标签”,每一组包含了相关的命令。每一个应用程序都有一个不同的标签组,展示了程序所提供的功能。在每个标签里,各种的相关的选项被组在一起。设计Ribbon的目的是为了使应用程序的功能更加易于发现和使用,减少了点击鼠标的次数。

简单的说,就是目前最新版office办公套件的那种风格。这种界面样式比菜单栏&工具栏的组织更易操作。

不多说,直接看截图吧。

项目开源在下面的链接中

把界面改了一下,开始实际填充功能。

它把命令组织成一组“标签”,每一组包含了相关的命令。每一个应用程序都有一个不同的标签组,展示了程序所提供的功能。在每个标签里,各种的相关的选项被组在一起。设计Ribbon的目的是为了使应用程序的功能更加易于发现和使用,减少了点击鼠标的次数。

简单的说,就是目前最新版office办公套件的那种风格。这种界面样式比菜单栏&工具栏的组织更易操作。

不多说,直接看截图吧。

项目开源在下面的链接中

把界面改了一下,开始实际填充功能。

它把命令组织成一组“标签”,每一组包含了相关的命令。每一个应用程序都有一个不同的标签组,展示了程序所提供的功能。在每个标签里,各种的相关的选项被组在一起。设计Ribbon的目的是为了使应用程序的功能更加易于发现和使用,减少了点击鼠标的次数。

简单的说,就是目前最新版office办公套件的那种风格。这种界面样式比菜单栏&工具栏的组织更易操作。

不多说,直接看截图吧。

项目开源在下面的链接中

}

我要回帖

更多关于 vue文章分享 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信