html标签的tabindex属性?css变量和js更改变量?ES6新增特性Map/WeakMap和Set/WeakSet

简介: tabindex 属性规定元素的 tab 键控制次序(当 tab 键用于导航时)。

一省:HTML

20. html标签的tabindex属性?

  1. tabindex 属性规定元素的 tab 键控制次序(当 tab 键用于导航时)。除此之外,大屏项目或者需要用遥控器操控的页面,tabindex都是必不可少的属性。
    <style>
    ul {
          
          
     display: flex;
    }
    li {
          
          
     width: 100px;
     height: 50px;
    }
    </style>
    <ul>
    <li tabindex="1">1</li>
    <li tabindex="2">2</li>
    <li tabindex="6">3</li>
    <li tabindex="4">4</li>
    <li tabindex="5">5</li>
    <li tabindex="6">6</li>
    </ul>
    

tabindex

二省: CSS

20. css变量和js更改变量?

定义全局变量,用var()方法使用,方便设置修改统一的颜色等。

<style>
  :root {
    
    
    --color: #ffffff;
    --bgColor: #000000;
  }
  ul {
    
    
    display: flex;
  }
  li {
    
    
    width: 100px;
    height: 50px;
    margin-right: 50px;
    list-style: none;
    color: var(--color);
    background: var(--bgColor);
  }
  button {
    
    
    margin-right: 30px;
  }
</style>
<ul>
  <li>导航1</li>
  <li>导航2</li>
  <li>导航3</li>
</ul>
<button onclick="changColor()">改变文字颜色</button>
<button onclick="changebgColor()">改变背景颜色</button>

<script>
  // 改变root文字颜色
  function changColor() {
    
    
    let root = document.querySelector(":root");
    console.log(root.style);
    root.style.setProperty("--color", "tomato")
  }
  // 改变root背景颜色
  function changebgColor() {
    
    
    let root = document.querySelector(":root")
    root.style.setProperty("--bgColor", "skyblue")
  }
</script>

css控制变量

三省:JavaScript

20. ES6新增特性Map/WeakMap和Set/WeakSet

1. Map: Map对象中保存键值对,任何数据类型(包括对象)都可以作为键/值。

// Map
// 初始化1
let map1 = new Map([["key1", "val1"],["key2", "val2"]])
console.log(map1);//Map(2) {'key1' => 'val1', 'key2' => 'val2'}
// 初始化
let obj = {
   
    name: "Jack" }
let map = new Map()
// set() 方法
map.set("str", "hello world")
map.set(obj, "abc")
map.set(1, 123)
console.log(map);//{'str' => 'hello world', {…} => 'abc', 1 => 123}

// has() 方法
console.log(map.has(obj));//true
console.log(map.has(1));//true
console.log(map.has(2));//false

// get() 方法
console.log(map.get(obj));//abc
console.log(map.get(1));//123
console.log(map.get("str"));//hello world
// size 属性
console.log(map.size);//3
// delete() 方法
// map.delete("str")
console.log(map.has("str"));//false
console.log(map.size);//2
// clear() 方法
// map.clear()
console.log(map.has(obj));//false
console.log(map.size);//0

// 遍历
map.forEach((item, key) => {
   
   
  console.log(item, key);
})

for(const item of map) {
   
   
  console.log(item[0], item[1]);
}

for(const [key, value] of map) {
   
   
  console.log(key, value);
}

2. WeakMap: WeakMap是Map的兄弟类型,与Map类型不同的地方是WeakMap只能用对象当做键,值可以是任意类型。还有就是WeakMap对象不可迭代。

// WeakMap
let obj = {
   
   name: "Jack"}
let weakmap = new WeakMap()
weakmap.set(obj, "abc");//WeakMap {
   
   {…} => 'abc'}
weakmap.set(2, "321");//报错 Uncaught TypeError: Invalid value used as weak map key
console.log(weakmap);

3. Set: Set对象是值的集合且 Set 中的元素只会出现一次,即 Set 中的元素是唯一的,所以Set可以用于数组去重。

// Set 
// 初始化1
let set1 = new Set(["val1", "val2", "val3"])
console.log(set1);//Set(3) {'val1', 'val2', 'val3'}
// 初始化
let set = new Set()
// add() 方法
set.add(1);
set.add(2);
set.add(3).add(4);
console.log(set);//Set(4) {1, 2, 3, 4}
// has() 方法
set.has(2);//true
// size 属性
console.log(set.size);//4
// delete() 方法
set.delete(1)
console.log(set);//Set(3) {2, 3, 4}
console.log(set.size);//3
// clear() 方法
set.clear();
console.log(set.has(2));//fasle
console.log(set.size);//0
// 迭代
set.forEach((item) => {
   
   
  console.log(item);
})
for(const item of set) {
   
   
  console.log(item);
}
// 去重
let arr = [1,1,2,3,2,3,4,5]
console.log([...new Set(arr)]);//[1, 2, 3, 4, 5]

4. WeakSet: WeakSet是Set的兄弟类型,与Set类型不同的地方是WeakSet中存的值只能是对象。还有就是WeakSet对象不可迭代。

// WeakSet
let weakset = new WeakSet()
let obj = {
   
   name: "Jack"}
weakset.add(obj);//WeakSet {name: 'Jack'}
weakset.add(2);//报错 Uncaught TypeError: Invalid value used in weak set
console.log(weakset);
相关文章
|
11天前
|
监控 JavaScript 前端开发
确定使用 `defer` 属性还是 `async` 属性来异步加载 JavaScript
【10月更文挑战第24天】选择使用 `defer` 属性还是 `async` 属性来异步加载 JavaScript 是一个需要综合考虑多个因素的决策。需要根据脚本之间的依赖关系、页面加载性能要求、脚本的功能和重要性等因素来进行权衡。在实际应用中,需要通过测试和验证来确定最适合的加载方式,以提供更好的用户体验和页面性能。
|
3天前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
9 3
|
8天前
|
存储 移动开发 前端开发
html5有哪些新特性?
【10月更文挑战第19天】
|
14天前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
64 6
|
11天前
|
监控 JavaScript 前端开发
使用 `defer` 属性异步加载 JavaScript
【10月更文挑战第24天】使用 `defer` 属性异步加载 JavaScript 是一种有效的提高页面性能和用户体验的方法。通过合理设置 `defer` 属性,可以在不影响页面渲染的情况下异步加载脚本,并确保脚本的执行顺序。在实际应用中,需要根据具体情况选择合适的加载方式,并注意处理可能出现的问题,以确保页面能够正常加载和执行。
|
29天前
|
移动开发 JavaScript 前端开发
原生js如何获取dom元素的自定义属性
原生js如何获取dom元素的自定义属性
41 4
|
1月前
|
缓存 JavaScript 前端开发
探索Vue.js中的计算属性与侦听器
【10月更文挑战第5天】探索Vue.js中的计算属性与侦听器
19 1
|
24天前
|
存储
ES6中的Set数据结构的常用方法和使用场景
ES6中的Set数据结构的常用方法和使用场景
|
24天前
|
JavaScript API
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
66 0
|
29天前
|
存储 JavaScript 前端开发
js中map属性
js中map属性
18 0
下一篇
无影云桌面