当前位置: 首页 > 编程日记 > 正文

vue从创建到完整的饿了么(5)v-for,v-bind与计算属性

说明

1.上一章--Home.vue及vue-resource使用
2.cangdu大神的项目源码地址--Github地址
3.接口地址--Github地址
4.UI框架用的是--Mint UI
5.下一章--登录注册页面及密码的暗明文转换

开始

1.先看看Home.vue代码

<template><div><mt-header fixed><span slot="left">elm</span><mt-button slot="right">登录|</mt-button><mt-button slot="right">注册</mt-button></mt-header><div class="padtop40"><div class="after ih50 padlr10 box bgfff"><span  class="">当前选择城市</span><span  class="right fs0-8 col9f">定位不准时,请在城市列表选择</span></div><mt-cell  title="天津" class="col after" to=""  is-link  value=""></mt-cell><div class="mgtop10 bgfff"><mt-cell class="after" title="热门城市"></mt-cell><div class="itembox ovhid col"><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div></div>        </div>         <div class="mgtop10 bgfff"><mt-cell class="after" title="A"></mt-cell><div class="itembox ovhid"><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div></div>        </div>    </div></div>
</template><script>export default {data () {return {}},component:{//注册组件},mounted:function(){//生命周期this.$http.get('http://cangdu.org:8001/v1/cities?type=group').then(response => {console.log(response);}, response => {console.log(response);});},computed:{//计算属性},methods:{//函数}
}
</script><!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.itembox>div{width:25%;float:left;text-align:center;height:40px;line-height:40px;box-sizing: border-box;border-right:1px solid #e4e4e4;border-bottom:1px solid #e4e4e4;
}
.itembox>div:nth-child(4n){border-right:0px;
}
</style>

效果如下图片描述

2.赋值

首先我们要把城市列表的信息先赋值给一个变量,这样我们就可以调用了嘛。图片描述

3.v-for
城市列表我们有了,但是我们怎么把它显示到页面呢?难道要用for循环拼接字符串插到页里么?NONONO,那还是操作DOM节点,而VUE的好处之一就是操作数据来控制DOM。循环VUE用的是v-for,home.vue的html部分代码修改如下

<template><div><mt-header fixed><span slot="left">elm</span><mt-button slot="right">登录|</mt-button><mt-button slot="right">注册</mt-button></mt-header><div class="padtop40"><div class="after ih50 padlr10 box bgfff"><span  class="">当前选择城市</span><span  class="right fs0-8 col9f">定位不准时,请在城市列表选择</span></div><mt-cell  title="天津" class="col after" to=""  is-link  value=""></mt-cell><div class="mgtop10 bgfff"><mt-cell class="after" title="热门城市"></mt-cell><div class="itembox ovhid col"><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div><div>天津</div></div>        </div>         <div v-for="(items,index) in citylist" class="mgtop10 bgfff"><mt-cell class="after" :title="index"></mt-cell><div class="itembox ovhid"><div v-for="item in items">{{item.name}}</div></div>        </div>  </div></div>
</template>

其实只是把全部城市列表的代码修改如下

 <div v-for="(items,index) in citylist" class="mgtop10 bgfff"><mt-cell class="after" :title="index"></mt-cell><div class="itembox ovhid"><div v-for="item in items">{{item.name}}</div></div>        </div>  

修改第一段代码v-for="(items,index) in citylist"
citylist是一个object对象(也可以是数组),itemscitylist的每一项键值,indexitems的键名(若为数组则是1,2,3...递增)。citylist有多少项,就会循环多少次,就会产生多少个元素(该元素为 v-for 写在的那个元素,其内的子元素也会自动生成)。然后就可以用item在元素中当做键值来使用。

修改第二段代码:title="index"
因为咱们获取的数据的键名就是A,B,C,D...所以咱们的城市列表直接用index来排序。而:title="index" v-bind:title="index"的缩写。vue的命令都用v-来开头。v-bind用来绑定DOM属性。

修改第三段代码<div v-for="item in items">{{item.name}}</div>
老铁们要注意,若items是A开头的城市数组集合,而itemitems的 每一项,即一个具体的城市(这只是举一个例子)

ok,代码咱们先写这么多,来看看页面变化。图片描述

全部出现!!老铁们可以看到,咱们只需要写一个模板,vue会帮我们自动生成所有的数据。但是还有几个问题需要处理一下
1.数据的顺序并不是从A挨个排到Z;
2.有的城市名字太长出现重叠。

4.排序
思路:重新创建一个object,键名是从A到Z,键值就是获取的数据的键值。
计算函数:js写在哪?一种方法是写在生命周期mounted的数据请求里,直接返回一个处理好的citylist,但咱们用另一种方法--计算属性computed。home.vue部分是代码修改如下

computed:{//计算属性getlist:function(){var mycitylist={};for(var i=65;i<=90;i++){var num= String.fromCharCode(i);mycitylist[num]=this.citylist[num];}return mycitylist}},

fromCharCode()是把ascii码转成字符,所以num就是A,B,C,D...当我们调用getlist函数时,得到的是mycitylist(当citylist改变时,无需重新调用,mycitylist会随之改变)
函数写好了在哪调用呢?

    <div v-for="(items,index) in getlist" class="mgtop10 bgfff"><mt-cell class="after" :title="index"></mt-cell><div class="itembox ovhid"><div v-for="item in items">{{item.name}}</div></div>        </div>  

只是把<template></template>中的citylist替换成getlist即可。
看看页面结果图片描述

解决!城市已经按照A-Z排列,只剩下名字长度问题了,设置为单行不换行超出省略号即可,在src下的style下的mycss.css添加

.nowarp{white-space:nowrap;          /* 不换行 */overflow:hidden;               /* 内容超出宽度时隐藏超出部分的内容 */text-overflow:ellipsis;   /* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一起使用。*/
}

nowarp这个class加到城市名字的div上即可
图片描述

解决。这么看城市列表是没有问题了,那咱们接下来请求热门城市和当前城市。home.vue修改如下

<template><div><mt-header fixed><span slot="left">elm</span><mt-button slot="right">登录|</mt-button><mt-button slot="right">注册</mt-button></mt-header><div class="padtop40"><div class="after ih50 padlr10 box bgfff"><span  class="">当前选择城市</span><span  class="right fs0-8 col9f">定位不准时,请在城市列表选择</span></div><mt-cell  :title="nowcity.name" class="col after" to=""  is-link  value=""></mt-cell><div class="mgtop10 bgfff"><mt-cell class="after" title="热门城市"></mt-cell><div class="itembox ovhid col"><div v-for="item in hotcity">{{item.name}}</div></div>        </div>         <div v-for="(items,index) in getlist" class="mgtop10 bgfff"><mt-cell class="after" :title="index"></mt-cell><div class="itembox ovhid"><div class="nowarp" v-for="item in items">{{item.name}}</div></div>        </div>  </div></div>
</template><script>export default {data () {return {citylist:"",hotcity:"",nowcity:""}},component:{//注册组件},mounted:function(){//生命周期//城市列表this.$http.get('http://cangdu.org:8001/v1/cities?type=group').then(response => {console.log(response);this.citylist=response.body;}, response => {console.log(response);});//热门城市this.$http.get('http://cangdu.org:8001/v1/cities?type=hot').then(response => {console.log(response);this.hotcity=response.body;}, response => {console.log(response);});//定位城市this.$http.get('http://cangdu.org:8001/v1/cities?type=guess').then(response => {console.log(response);this.nowcity=response.body;}, response => {console.log(response);});},computed:{//计算属性getlist:function(){var mycitylist={};for(var i=65;i<=90;i++){var num= String.fromCharCode(i);mycitylist[num]=this.citylist[num];}return mycitylist}},methods:{//函数}
}
</script><!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.itembox>div{width:25%;float:left;text-align:center;height:40px;line-height:40px;box-sizing: border-box;border-right:1px solid #e4e4e4;border-bottom:1px solid #e4e4e4;
}
.itembox>div:nth-child(4n){border-right:0px;
}
</style>

页面结果如下图片描述
搞定!home.vue大致写完了,剩下就是交互了

相关文章:

python查询mysql中文乱码问题

相信很多在工作中的Python小伙伴&#xff0c;经常会遇到一些工作上的问题&#xff0c;例如查询mysql中文乱码问题&#xff0c;Python连接mysql数据库时&#xff0c;读取数据库中的中文出现乱码&#xff0c;所有中文都显示为问号了&#xff0c;那么该如何解决这个问题呢?解决问…

技术图文:如何利用C# + Echarts 绘制「堆叠条形图」?

背景 前几天&#xff0c;我们介绍了 如何利用C# Echarts 绘制 Bar Simple&#xff1f;&#xff0c;原以为把 Echarts 封装到这种程度就可以完成当前任务了。 可是&#xff0c;把软件原型提交给对方时&#xff0c;发现对方更希望“可视化设备发生缺陷的具体数据”。也即利用 堆…

Javascript原型链

这是关于原型链的一系列的现象与原理的解释以及例子 【转载请注明出处与地址】 分成4个部分阐述&#xff1a; 1.如何创建一个对象 2.使用原型链prototype实现对象的继承. 3.原型链上属性和方法的联系与规则 4.深入剖析原型链。 一、如何创建一个对象&#xff1a; 1.使用关键字n…

springbatch apache-activemq 整合(往mq中put数据,从mq中take数据)

简单测试如下&#xff1a;1&#xff1a;收下下载apache-activemq-5.14.4 解压apache-activemq-5.14.4\bin\win64&#xff0c;运行activemq.bat启动本地MQ服务器。通过浏览器可以查看本地MQ服务器的信息。http://127.0.0.1:8161/admin/index.jsp 2: 先往mq中put数据配置如下&…

什么是安全测试?哪些阶段需要安全测试?

安全测试是在IT软件产品的生命周期中&#xff0c;特别是产品开发基本完成到发布阶段&#xff0c;对产品进行检验以验证产品符合安全需求定义和产品质量标准的过程&#xff0c;可以说&#xff0c;安全测试贯穿于软件的整个生命周期。下面通过一张图描述软件生命周期各个阶段的安…

技术图文:如何利用C#爬取CSDN的博客文章?

背景 大家有没有这样的体验&#xff0c;在 CSDN 上发现某个博主有很多干货文章&#xff0c;我们就想拿到这个博主以往文章的列表&#xff0c;在需要的时候进行查询和浏览。 如果从 CSDN 网站上用复制粘贴的方式来建立这个列表&#xff0c;一个是工作量很大&#xff0c;另一个…

SAP BADI应用

SAP BADI应用 1.定义BADI 1) T-Code: SE18 Business Add-In Define. 2) 输入要创建的BADI的名字&#xff0c;点击"Create"。 3) 输入BADI的描述性文本&#xff0c;在"Interface"选项卡上输入接口的名字&#xff0c;也可以采用SAP建议的接口的…

为什么多 TCP 连接比单 TCP 连接传输快

转自&#xff1a; 我观察到&#xff0c;客户端机器从单一服务器使用 HTTP 下载一个文件&#xff1a;1. 单连接下载&#xff0c;速度没有达到客户端网络的最大带宽&#xff1b;2. 多连接同时下载&#xff0c;传输速度有极大的提高&#xff0c;带宽被占满。假设如下前提&#xff…

学Python的好处有哪些?

Python是一种比较简单的编程语言技术&#xff0c;想要快速进入到IT行业&#xff0c;Python是非常好的选择&#xff0c;为什么这么说呢?下面小编就为大家详细的介绍一下学Python的好处有哪些? ​  学Python的好处有哪些? 1.如果你是一名新媒体相关人员&#xff0c;学习Pyth…

技术图文:如何利用C# 实现 Kruskal 最小生成树算法?

背景 以前我写过一些图文来介绍有关数据结构与算法的知识&#xff1a; 8大排序算法之&#xff1a;直接插入排序&#xff08;Straight Insertion Sort&#xff09;8大排序算法之&#xff1a;希尔插入排序&#xff08;Shell Insertion Sort&#xff09;8大排序算法之&#xff1…

又偷懒了4个月,督促自己

又偷懒了4个月 每天浑浑噩噩&#xff0c;做着无聊简单的体力活&#xff0c;我不应该是这个追求撒&#xff01;~~ 爸爸说的对&#xff0c;无论怎么样自己都要独立&#xff0c;要学习&#xff0c;爸爸希望我还去继续学习会计&#xff0c;我看下半年吧&#xff0c;各种学习都要&am…

java.lang.NoSuchMethodError: org.springframework.web.context.support.XmlWebApplicationContext.getEnv

转自&#xff1a;https://blog.csdn.net/u012941811/article/details/16960493 ava.lang.NoSuchMethodError: org.springframework.web.context.support.XmlWebApplicationContext.getEnvironment()Lorg/springframework/core/env/ConfigurableEnvironment; at 缺 org.springf…

零基础可以学好UI设计吗

随着UI设计行业的不断扩大发展&#xff0c;很多人都想要学习UI设计技术&#xff0c;但有很多同学都是零基础&#xff0c;想知道零基础可以学好UI设计吗?我们来看看下面的详细介绍就知道了。 零基础可以学好UI设计吗? 如果零基础自己学习UI设计着实有点吃力&#xff0c;毕竟对…

技术图文:如何利用C# 实现 Prim 最小生成树算法?

背景 我们上一篇图文介绍了 如何利用 C# 实现 Kruskal 最小生成树算法&#xff1f;&#xff0c;Kruskal 算法通过寻找边最优的方式来构造最小生成树&#xff0c;本篇图文介绍如何利用 C# 实现 Prim 最小生成树算法&#xff0c;Prim 算法通过寻找顶点最优的方式来构造最小生成树…

去除iphone图标的半弧高亮效果

只需要在info.plist里面添加一条记录UIPrerenderedIcon 新版的XCODE 会自动识别为Icon already includes gloss effects 打上勾就OK了 如果没有识别的右边栏写上YES就可以。转载于:https://www.cnblogs.com/jiewong/archive/2011/01/14/1935718.html

【短视频SDK - 参数解析】对焦模式、裁剪模式、视频质量、分辨率、视频比例、帧率、关键帧间隔等参数解析...

1.参数简析 参数名称简介影响裁剪模式分为填充模式和裁剪模式影响图像画面的展示细节视频质量是指生成的视频的输出参数&#xff0c;是一组参数决定的数值视频清晰度和文件大小分辨率图像分辨率则是单位英寸中所包含的像素点数&#xff0c;分辨率影响图像大小&#xff0c;与图像…

21年最新Python面试题及答案汇总详解(上)

错过三月找工作的机会&#xff0c;还要错过四月的好时期吗?Python面试你做准备了吗?下面小编整理了一套2021年最新Python常见面试题目&#xff0c;及Python面试题目答案汇总。希望能够帮助到大家。 21年最新Python面试题及答案汇总详解(上) 1、列表(list)和元组(tuple)有什么…

sina微博api源码阅读之函数

1. array_map将类的静态成员函数作为回调函数用在指定的单元上&#xff0c;可以递归调用 public static function urlencode_rfc3986($input) { if (is_array($input)) { return array_map(array(OAuthUtil, urlencode_rfc3986), $input); } else …

LeetCode实战:将有序数组转换为二叉搜索树

题目英文 Given an array where elements are sorted in ascending order, convert it to a height balanced BST. For this problem, a height-balanced binary tree is defined as a binary tree in which the depth of the two subtrees of every node never differ by mo…

Spring、Spring Boot和TestNG测试指南 - @ActiveProfiles

Github地址 ActiveProfiles可以用来在测试的时候启用某些Profile的Bean。本章节的测试代码使用了下面的这个配置&#xff1a; Configuration public class Config {BeanProfile("dev")public Foo fooDev() {return new Foo("dev");}BeanProfile("prod…

python语言中如何使用注释

每一种计算机语言都有自己的注释方式&#xff0c;我们知道注释的作用是解释这些代码&#xff0c;方便程序员以后的检查和修改。而且注释的一部分在运行程序的过程中不起作用&#xff0c;也不会显示出来。下面我们将为大家介绍&#xff0c;在python语言中如何使用注释? 在pytho…

RHEL5(CentOS)下nginx+php+mysql+tomcat+memchached配置全过程(转)

RHEL5(CentOS)下nginxphpmysqltomcatmemchached配置全过程 一、准备工作&#xff1a; SSH,telnet终端中文显示乱码解决办法 vi /etc/sysconfig/i18n将内容改为 LANG"zh_CN.GB18030" LANGUAGE"zh_CN.GB18030:zh_CN.GB2312:zh_CN" SUPPORTED"zh_CN.GB18…

LeetCode实战:搜索二维矩阵

题目英文 Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the following properties: Integers in each row are sorted from left to right.The first integer of each row is greater than the last integer of the previou…

windows指令

为什么80%的码农都做不了架构师&#xff1f;>>> C:\Windows\System32\drivers\etc nbtstat -a 1.7.2.2s 检查该IP的主机名称 WExNmU5Z windows启动配置界面 在“运行”中输入“msconfig mstsc -admin 远程 虚拟机的判断&#xff1a;如果有vmtoolsd.exe进程就是虚拟…

Java培训好不好?零基础可以学吗?

5g时代的来临&#xff0c;越来越多的人开启智能时代&#xff0c;互联网行业的发展速度越来越快&#xff0c;高薪行业一直受到很多人的关注&#xff0c;尤其是java这一块&#xff0c;很多人都想学习&#xff0c;那么参加Java培训好不好?零基础可以学吗? Java培训好不好?零基础…

顺水行舟,逆水行舟

水&#xff0c;或温柔&#xff0c;或猛烈 万物皆可比喻为水 顺水行舟&#xff0c;逆水行舟&#xff0c;皆为操船者智慧之体现 翻船者。。。把船搞翻了几回还执意而为&#xff0c;SB也。。。转载于:https://www.cnblogs.com/Zetazzz/archive/2011/01/30/1948082.html

LeetCode实战:二叉树的最大深度

题目英文 Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along the longest path from the root node down to the farthest leaf node. Note: A leaf is a node with no children. Example: Given binary tree [3,9,20,null,n…

jfinal整合shiro回顾

2019独角兽企业重金招聘Python工程师标准>>> 目前jfinal使用shiro进行身份验证和授权的后台实现已完成&#xff0c;现在我再来总结下学习过程及代码实现过程。最近半年多项目开发都用.net&#xff0c;但又不甘心用了一年多的java&#xff0c;jfinal就这样被废弃&…

零基础学习Java培训有什么攻略

零基础学习Java培训有什么攻略?java是主流编程语言之一&#xff0c;我们在学习Java的时候需要制定Java学习路线图&#xff0c;Java涉及到的知识点非常的多&#xff0c;我们该从何学起呢?怎么系统的学习呢?来看看下面的详细介绍。 一、Java学习阶段 将Java学习过程分为3个阶段…

php去掉字符串的最后一个字符 substr()的用法

今天项目中用到&#xff0c;去掉字符串中的最后一个字符原字符串1,2,3,4,5,6,去掉最后一个字符","&#xff0c;最终结果为1,2,3,4,5,6代码如下&#xff1a;$str "1,2,3,4,5,6,"; $newstr substr($str,0,strlen($str)-1);echo $newstr;系统自带的函数也可…