当前位置:   article > 正文

vue的script动态改css、scss变量方法_scss变量能否动态改变

scss变量能否动态改变

 

解决场景:script设颜色变量,<style>的background-color的值"#ddd"的跟着变

   序     

        1、这篇博文适用vue2和vue3版本,博主实验时,vue3的版本是^3.2.45

        2、 其实要解决的方案在vue3里有一个专栏“单文件组件的 <style> 标签支持使用 v-bind CSS 函数将 CSS 的值链接到动态的组件状态

       3、对了这里说下,原来vue3的style vars={color}属性已经不能用了,被其他方法替代了,详情去看这篇官方文档-》SFC style CSS variable injection (new edition) by yyx990803 · Pull Request #231 · vuejs/rfcs · GitHub

        4、如果你纯vue3没用!任何!第三方!框架(vue-class-component也算第三方工具!!!),你直接考下面这个demo,直接是可以跑的,下面demo你还用不了,你在往博文下面看

  1. <template>
  2. <div class="text">hello</div>
  3. </template>
  4. <script>
  5. export default {
  6. data() {
  7. return {
  8. color: 'red'
  9. }
  10. }
  11. }
  12. </script>
  13. <style>
  14. .text {
  15. color: v-bind(color);
  16. }
  17. </style>

        好了正文,如果上面demo你跑不了,你确认下是不是vue3版本比博主低?

        博主以下说的是vue2、和vue3+ts版本、vue3的sass版本、vue3的vue-class-component工具类、vue3的vue-property-decorator工具类都可以执行的方法。

        先科普下,别闲博主烦,照着先做↓↓↓↓↓↓

  1. <html>
  2. <head>
  3. </head>
  4. <body>
  5. <input type="text"/>
  6. <style>
  7. :root {
  8. --color: pink;
  9. }
  10. input {
  11. background-color: var(--color);
  12. }
  13. </style>
  14. </body>
  15. </html>

        以上代码运行之后的结果如下图,input的北京变成红色。是吧,这个是纯静态是".html"的文件哦

root{--color:red;},这个时候你可以认为是声明变量。 然后在你要放变量的地方var(--color)就可以调用了,

        以上为灵感,结合在vue2博主百度了些资料,搞了个通用方法如下

切记你别连vue-property-decorator也复制了,这里弄vue-property-decorator是告诉你他也可以用

  1. <template>
  2. <a class="sumbit-btn" :style="'--color:'+color" >登录</a>
  3. </template>
  4. <script lang="ts">
  5. import {
  6. Vue
  7. } from "vue-property-decorator";
  8. export default class Login extends Vue {
  9. data(){
  10. return{
  11. color:"red",
  12. }
  13. }
  14. }
  15. </script>
  16. <style lang="scss">
  17. .sumbit-btn{
  18. color:var(--color);
  19. }
  20. </style>

结果如下图

 

扩展

--color 你可以写在vue的computed函数里、或者methods函数里定义一个方法,然后这里style就可以直接:style="style()"这句话要看的懂

  1. <template>
  2. <a class="sumbit-btn" :style="style" >登录</a>
  3. </template>
  1. data(){
  2. return{
  3. color:"red",
  4. }
  5. }
  1. computed: {
  2. style() {
  3. return {
  4. "--color": this.color
  5. };
  6. }
  7. }

博文为雪狼博主原创,博客地址: 雪狼之夜的博客_CSDN博客-vue,eggjs,js领域博主

原创不易,点个赞呗。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/82234
推荐阅读
相关标签
  

闽ICP备14008679号