V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
imherer
V2EX  ›  程序员

Vue 如何控制 layout 的 css

  •  
  •   imherer · 2019-04-15 15:03:23 +08:00 · 1764 次点击
    这是一个创建于 2055 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

    5 条回复    2019-04-15 17:07:17 +08:00
    leekoho
        1
    leekoho  
       2019-04-15 15:31:23 +08:00   ❤️ 1
    在 layout 里面 watch 一下$route, 将背景图的 src 替换
    keepeye
        2
    keepeye  
       2019-04-15 15:49:10 +08:00
    别在 mounted 做,通过 activated
    imherer
        3
    imherer  
    OP
       2019-04-15 15:51:11 +08:00
    @keepeye 谢谢。 已经通过 1 楼的方法解决了。这样就不用在每个页面下写代码了
    choujiaojiao
        4
    choujiaojiao  
       2019-04-15 15:51:55 +08:00   ❤️ 1
    mounted 函数只会执行一次
    ochatokori
        5
    ochatokori  
       2019-04-15 17:07:17 +08:00 via Android   ❤️ 1
    如果用了 keep-alive 的话 mounted 只会执行第一次
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2277 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 00:54 · PVG 08:54 · LAX 16:54 · JFK 19:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.