商城搜索页面前端的渲染(包括做出搜索结果集的显示,图片会根据鼠标的移动而显示,标题副标题也会跟着切换,json对象转换为字符串的方法,和字符串转换为json对象的方法)

我们做好了一个页面后,可以看到我们的这个页面里面有很多null的字段,是空的字段,这些字段我们都不想它能够显示在控制台,这样才会整洁很多,那该怎么样才能把它们去掉呢?
在这里插入图片描述
我们可以在search模块的yml配置里面加上这个配置,non_null,表示如果为null的话就不会显示,always代表全部显示。这是spring的特色功能
在这里插入图片描述
重启一下,发现都没有了。
在这里插入图片描述
打开items一看,我们已经拿到了响应的数据了,但是还没有进行渲染,接下来我们就可以进行渲染了。

在这里插入图片描述
我们该如何进行渲染呢?首先可以看到下面这个方法本来是这样的

在这里插入图片描述

我们把
在这里插入图片描述
因为我们要拿到下面的这个items,我们之前是定义了一个空集合goodsList,就可以用这个goodsList来接收items,如上图所示
在这里插入图片描述
然后我们就要找到我们对应的组件进行渲染了,下面的detail就是商品详情表,里面有个goods-list

在这里插入图片描述
下面这一块就是上面的selector选择块。
在这里插入图片描述
展开list后我们可以看到一个无序列表,这些代表每一个商品

在这里插入图片描述

可以看到它的里面有图片有价格集合等等。
在这里插入图片描述
我们删掉其他的商品list,然后用这个遍历方法遍历商品,用key方法比较快一点

在这里插入图片描述
看我们这里是个json字符串,我们要去渲染它,就要把它进行转换成json对象

在这里插入图片描述

用JSON.parse方法就可以实现把字符串转换为Json对象,然后用goods.skus来接收
在这里插入图片描述

然后这里的图片可以都删掉
在这里插入图片描述
然后加入这些信息,v-for里面的是双重遍历,也就是sku和j都得到遍历,最后传入图片

在这里插入图片描述

启动后我们可以发现一个问题,选中一个图片后,其他所有的图片都会被选中,这是为什么呢?
在这里插入图片描述
因为这个选择方法规定了你选择一条就等于选择全部了,所以我们要去规定选中一条等于只能选中一条,并且每个goods选中了某一个图片后只能在当前的goods里面生效,所以我们需要在每一个goods里面去写上这个唯一性的方法。
在这里插入图片描述

首先我们先来加上这个方法,这个方法代表默认情况下显示哪个图片,我们默认情况下显示第一个图片
在这里插入图片描述
这里我们改成样式方法,这个方式方法在“:”后面表示如果符合后面的值,就会执行这个方法,如果不符合则为false,在这里的话,如果我们选择了其他图片就相当于选择了其他sku,sku的id就会不一样,所以它也就不会显示原来的图片了。
在这里插入图片描述
效果如下,但是有个缺点,就是红框不会随着鼠标的移动而移动。
在这里插入图片描述
添加一个鼠标的移动事件就可以了。
在这里插入图片描述

但是我们可以看到,把鼠标放在图片上依然没有红框出现进行显示
在这里插入图片描述

因为这个是一开始就赋值了的,有图片还有sku的信息,一开始就已经赋值给了默认值
在这里插入图片描述
如果我们把它放在后面,那么它就会等调整好数据后再进行赋值
在这里插入图片描述
重新刷新,可以看到它移动了。
在这里插入图片描述

然后剩下的价格,标题,副标题我们也可以渲染了。
在这里插入图片描述
图片改上这个就会跟着变化了

在这里插入图片描述
可以看到价格本来是这样的,要想它产生变化,我们应该改成什么呢?
在这里插入图片描述
我们应该改成这样。跟着选择价格

在这里插入图片描述
标题和副标题方法也是一样
在这里插入图片描述
然后看看别人的网站,鼠标放在标题上会弹出个小框显示全部文字。

在这里插入图片描述
所以我们需要做一个判断,也就是如果这个标题长度大于20,就截取0到20个文字,如果小于20则显示,副标题也是同样的做法。
在这里插入图片描述
结果遇到问题了,渲染不出来了,是什么错误呢?它说formatPrice是个未定义的属性

在这里插入图片描述

要注意的是,在html里面你只能引入vue的实例,ly这个并没有实例化,所以显示失败(这里除了价格外,其他的比如图片等等也没有实例)
在这里插入图片描述
所以你要在这里引入实例

在这里插入图片描述

那有人可能会问这里之前也是没有实例为什么这个可以去用,因为下面这个是在js当中。
在这里插入图片描述

重新刷新一下,可以显示了
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值