JavaScript编写css自定义属性的示例代码
更新时间:2024年12月10日 09:21:18 作者:前端熊猫
自定义属性(有时候也被称作CSS变量或者级联变量)是由CSS作者定义的,它包含的值可以在整个文档中重复使用,由自定义属性标记设定值,,由var() 函数来获取值,本文就给大家介绍了JavaScript编写css自定义属性,需要的朋友可以参考下
一、自定义属性
是在 CSS 中定义的变量,以 --开头。它们可以存储颜色、尺寸、字体等任何 CSS 值,并且可以在整个文档中重复使用。
:root { --primary-color: #3498db; --font-size: 16px; } body { color: var(--primary-color); font-size: var(--font-size); }
二、定义自定义属性
自定义属性通常在 :root
选择器中定义,这样它们就可以在整个文档中全局使用。不过,你也可以在任何选择器中定义自定义属性,使其作用域仅限于该选择器及其子元素局部。
/* 全局定义 */ :root { --main-bg-color: #f0f0f0; } /* 局部定义 */ .header { --header-height: 60px; height: var(--header-height); }
三、使用自定义属性
使用 var()
函数来引用自定义属性
.button { background-color: var(--primary-color); padding: var(--padding, 10px); /* 提供默认值 */ }
四、JS动态修改自定义属性
const element = document.querySelector('.container'); element.style.setProperty('--local-color', '#0000ff'); // 修改局部变量 document.documentElement.style.setProperty('--global-color', '#00ffff'); // 修改全局变量
五、应用
<template> <div ref="leftBg" class="left-bg"></div> <button @click="updateTitleImageClass">切换伪类图片</button> </template> <script setup> import { ref, onMounted } from 'vue'; const leftBg = ref(null); const systemTitles = ['cat1', 'cat2', 'cat3']; let currentTitleIndex = 0; const getBackgroundSize = (title) => { // 根据标题返回不同的背景大小 switch (title) { case 'cat1': return 'contain'; case 'cat2': return 'cover'; case 'cat3': return 'auto'; default: return 'cover'; } }; const images = {}; const loadImages = async () => { for (const title of systemTitles) { try { const response = await fetch(`/${title}/title.jpg`); if (!response.ok) { throw new Error(`Failed to fetch image for ${title}`); } const blob = await response.blob(); images[`/${title}/title.jpg`] = URL.createObjectURL(blob); } catch (error) { console.error(`Error loading image for ${title}:`, error); } } }; onMounted( async () => { await loadImages(); updateTitleImageClass(); } ); const updateTitleImageClass = async () => { if (!leftBg.value) { console.error('没有找到leftBg节点'); return; } const systemTitle = systemTitles[currentTitleIndex]; const imagePath = `/${systemTitle}/title.jpg`; // 根据系统标题获取图片路径 if (!images[imagePath]) { console.log(`没有找到对应的图片路径: ${imagePath}`); return; } const imageUrl = images[imagePath]; // 获取图片路径 // 设置自定义属性 leftBg.value.style.setProperty('--background-image', `url(${imageUrl})`); const backgroundSize = getBackgroundSize(systemTitle); leftBg.value.style.setProperty('--background-image-size', backgroundSize); // 切换到下一个标题 currentTitleIndex = (currentTitleIndex + 1) % systemTitles.length; }; </script> <style lang="scss" scoped> .left-bg { width: 100%; height: 100px; position: relative; &::before { content: ''; display: block; background-image: var(--background-image); background-size: var(--background-image-size, cover); background-position: center; background-repeat: no-repeat; width: 100px; height: 100%; position: absolute; top: 0rem; left: 0rem; } } </style>
到此这篇关于JavaScript编写css自定义属性的示例代码的文章就介绍到这了,更多相关JavaScript css自定义属性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
JavaScript遍历数组的三种方法map、forEach与filter实例详解
这篇文章主要介绍了JavaScript遍历数组的三种方法map、forEach与filter,结合实例形式详细分析了javascript针对数组遍历的map、forEach与filter三种方法相关操作技巧与注意事项,需要的朋友可以参考下2019-02-02JS生态系统加速一次一库PostCSS SVGO的重构源码和性能优化探索
这篇文章主要介绍了JS生态系统加速一次一库PostCSS SVGO的重构源码和性能优化探索,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2024-01-01
最新评论