Vue 如何控制 layout 的 css

2019-04-15 15:03:23 +08:00
 imherer

需求是这样的:我有一个layout页面,这个页面上有一张很大的背景图,基于layout这个页面做 3 个页面,叫A,B,C

ABC这 3 个页面的背景图是不一样的,我怎么在分别加载这 3 个页面的时候把背景图换掉呢?(就是换掉 layout 页面上那张大的背景图)

我现在的做法是分别在 ABC 这 3 个页面下通过 js 把背景给换掉(在 mounted 函数里),但是现在有个问题就是从 A 到 B 背景换掉了也正常,但是再回到 A 背景却还是 B 的应该怎么处理呢? 不能刷新页面!

1770 次点击
所在节点    程序员
5 条回复
leekoho
2019-04-15 15:31:23 +08:00
在 layout 里面 watch 一下$route, 将背景图的 src 替换
keepeye
2019-04-15 15:49:10 +08:00
别在 mounted 做,通过 activated
imherer
2019-04-15 15:51:11 +08:00
@keepeye 谢谢。 已经通过 1 楼的方法解决了。这样就不用在每个页面下写代码了
choujiaojiao
2019-04-15 15:51:55 +08:00
mounted 函数只会执行一次
ochatokori
2019-04-15 17:07:17 +08:00
如果用了 keep-alive 的话 mounted 只会执行第一次

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/555329

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX