第一次使用Vue
什么是Vue?
接触前端时,一直在想,网页中那么多数据,怎么一次性渲染到页面中?通过js可以实现,但是比较繁琐,需要组合字符串,很麻烦。还有更好的办法吗?
直到我遇见了Vue......
首次接触到Vue,进了官网,看到官方介绍视频我就已经跃跃欲试了,真的非常方便!
总的来说,Vue可以把网页中的各种数据集中到一起,用数组的方式调用,并且还支持循环这样的方式调用(当然,目前我还是小白,更高级的功能需要进一步探索)。
上手实战
正好我的博客需要写一个能够快速添加博客友链的功能,希望能够做到,当有新的友链要新增时,只需要维护基础数据即可,而不再像以前一样,又重新写html各种div。
源码展示
<div id="app">
<div id="friedsGroup">
<div class="friends" v-for="friend in friends">
<div class="friendCard">
<a :href="friend.blogUrl" target="_blank" class="item">
<img :src="friend.avatarUrl" alt="" />
<div class="info">
<p class="name">{{friend.blogName}}</p>
<p class="sign">{{friend.blogSign}}</p>
</div>
</a>
</div>
</div>
</div>
</div>
<myscript>
new Vue({
el: '#app',
data: {
friends: [
{
blogName:'YJLAugus',
blogUrl:'https://www.cnblogs.com/yjlaugus/',
avatarUrl: 'https://pic.cnblogs.com/avatar/1176586/20190523174806.png',
blogSign: '尽长安'
},
{
blogName:'麋鹿鲁哟',
blogUrl:'https://www.cnblogs.com/miluluyo/',
avatarUrl: 'https://pic.cnblogs.com/avatar/1273193/20190806180831.png',
blogSign: '大道至简,知易行难。'
},
]
}
})
</myscript>
遇到的问题
- 怎么存储数据?
Vue采取的是json格式的数据存储方式:
friends: [
{
blogName:'YJLAugus',
blogUrl:'https://www.cnblogs.com/yjlaugus/',
avatarUrl: 'https://pic.cnblogs.com/avatar/1176586/20190523174806.png',
blogSign: '尽长安'
},
{
blogName:'麋鹿鲁哟',
blogUrl:'https://www.cnblogs.com/miluluyo/',
avatarUrl: 'https://pic.cnblogs.com/avatar/1273193/20190806180831.png',
blogSign: '大道至简,知易行难。'
},
]
- 在哪调用?
首先要告诉Vue要在哪里解析,一般用下面的格式包裹需要运行Vue的html,然后在script中创建Vue实例。
<div id="app">
......
</div>
<script>
new Vue({
el: '#app',
data: {
...
}
</script>
这里因为要在博客正文里运行脚本,而博客园是不能运行的(因为script标签会被解析没了),我们采取了改标签的方式,用代码执行其中的内容。
<!-- 在文章内运行代码 -->
<script>
$(function() {
$('myscript').each(function() {
$(this).css('display','none');
eval($(this).text());
});
});
</script>
- 怎么调用?
数据调用一般采用json格式,用两对花括号{{}}
包裹起来,放到调用的位置(一般是div内部的文字内容):
{{friend.blogName}}
这里遇到了一个小插曲,含有网页链接的位置,像上面那样调用,会失败。查资料后,没太看懂,大概意思就是解析成了本网站内部的资源链接(网址为前缀为网站网址)。修改后的资源调用方式:
:href="friend.blogUrl"
在前面加一个 :
,然后调用的数据不用花括号包裹。
- 怎么循环调用?
循环调用时,只需要在循环的父div标签里添加下面的内容:
v-for="friend in friends"
其中前面的friend
是自己定义的临时变量,in
相当于循环语法,friends
是数据中的名字
实践成果
经过一番折腾,终于实现了前面所说的要求。点此查看。
值得注意的时,在打开界面时,会有一定的延时,看得到还没解析成功的那些字符,不过这不影响使用。
第一次使用Vue的更多相关文章
- 【保姆级教学】新手第一次搭建vue项目和初始化
前端项目初始化步骤 安装vue脚手架 通过vue脚手架创建项目 配置vue路由 配置Element-UI组件库 配置axios库 初始化git远程仓库 将本地项目托管到github或者码云上 通过vu ...
- Vue.js 系列教程 ①
原文:intro-to-vue-1-rendering-directives-events 译者:nzbin 如果要我用一句话描述使用 Vue 的经历,我可能会说“它如此合乎常理”或者“它提供给我需要 ...
- 基于 Laravel 开发 ThinkSNS+ 中前端的抉择(webpack/Vue)踩坑日记【ThinkSNS+研发日记系列】
在上一篇文章< ThinkSNS+基于Laravel master分支,从1到 0,再到0.1>,简单的介绍了 社群系统ThinkSNS+ ,这里分享在开发过程中,前端选择的心理活动. L ...
- 用vue开发一个app(2,main.js)
昨天跟着vue的官网搭建了vue的一个脚手架,我也是第一次用VUE一切都在摸索阶段. 今天试着看下里面脚手架里面有点什么东西 先看看main.js 导入了3个模块 一个vue,一个app,还有rout ...
- 关于Vue问题记录
第一次安装Vue时,npm run dev报错处理 1.如果是报错:提示说没找到test这个文件夹 参考资料:https://segmentfault.com/q/1010000010893904 就 ...
- vue数据请求
我是vue菜鸟,第一次用vue做项目,写一些自己的理解,可能有些不正确,欢迎纠正. vue开发环境要配置本地代理服务.把config文件加下的index.js里的dev添加一些内容, dev: { e ...
- Vue:渲染、指令、事件、组件、Props、Slots
如果要我用一句话描述使用 Vue 的经历,我可能会说“它如此合乎常理”或者“它提供给我需要的工具,而且没有妨碍我的工作”.每当学习 Vue 的时候,我都很高兴,因为很有意义,而且很优雅. 以上是我对 ...
- 搭建vue项目环境
前言 在开发本项目之前,我对vue,react,angular等框架了解,仅限于知道它们是什么框架,他们的核心是什么,但是并没有实际使用过(angular 1.0版本用过,因为太难用,所以对这类框架都 ...
- 一丢丢学习之webpack4 + Vue单文件组件的应用
之前刚学了一些Vue的皮毛于是写了一个本地播放器https://github.com/liwenchi123000/Local-Music-Player,如果觉得ok的朋友可以给个star. 就是很简 ...
随机推荐
- Vue日历组件的功能
本来呢,开开心心的写完了这个功能,然后发现elemeng更新了,增加了日历组件这个功能 我的内心机器奔溃,但是,element的日历组件太简单了,我感觉还是手撸一个吧,毕竟也不是很难 实现了显示农历, ...
- android studio学习---菜单栏BUILD功能
项目构建: 1.构建项目 2.重构项目 3.签名打包
- Python Django 实现简单注册功能
Python Django 实现简单注册功能 项目创建略,可参考前期文档介绍. 目录结构如下 编辑views.py from django.shortcuts import render # Crea ...
- ThinkPHP3.2.3:使用模块映射隐藏后台真实访问地址(如:替换url里的admin字眼)
例如:项目应用目录/Application下模块如下,默认后台模块为Admin 现在需要修改后台模块的访问地址,以防被别有用心的人很容易就猜到,然后各种乱搞... (在公共配置文件/Applicati ...
- c语言基础之getopt()
getopt() #include <unistd.h> int getopt(int argc, char * const argv[], const char *optstring); ...
- mysql 忘记密码,赋予用户权限,两台服务器的数据库之间快速导入
mysql 忘记密码: 1.首先service mysql stop mysqld --skip-grant-tables & 开启数据库 然后就可以mysql -uroot 直接进数据库, ...
- Spring Boot Admin 2.1.0
原文:https://blog.csdn.net/forezp/article/details/86105850 Spring Boot Admin简介 Spring Boot Admin是一个开源社 ...
- MobiSystems OfficeSuite 3.60.27307
官网:https://www.mobisystems.com/ 或 https://www.officesuitenow.com/cn/ MobiSystems OfficeSuite 3.60.27 ...
- luoguP5495:Dirichlet 前缀和
题意:给定数组a[]的生成方式,然后b[i]=∑a[j] ,(i%j==0),求所有b[i]的异或和.所有运算%2^32; 思路:高维前缀和的思想,先筛出所有素数,然后把每个素数当成一维,那么分开考 ...
- 性能测试:TPS和QPS的区别
做测试,各种ps,jps,tps,qps,rps,hps,你理解几个? 技术群里,问得最多的就是tps和qps,有相似的地方,也有差异的地方,我简单谈下自己的理解.(由于比较忙,下面部分摘抄自网络) ...