json数据和字符串json数据相互转换
- 1.json数据和字符串json数据相互转换
- 2.本地存储(localStorage、sessionStorage)
- 3.audio的属性、事件、方法
- 3.1属性
- 3.2事件
- 3.3方法
- 4.video的属性、事件、方法
- 4.1属性
- 4.2事件
- 4.3方法
1.json数据和字符串json数据相互转换
JSON 是一种基于文本的轻量级的数据交换格式。它可以被任何的编程语言读取和作为数据格式来传递。在项目开发中,使用 JSON 作为前后端数据交换的方式。在前端通过将一个符合 JSON 格式的数据结构序列化为 JSON 字符串,然后将它传递到后端,后端通过 JSON 格式的字符串解析后生成对应的数据结构,以此来实现前后端数据的一个传递。因为 JSON 的语法是基于 js 的,因此很容易将 JSON 和 js 中的对象弄混,但是应该注意的是 JSON 和 js 中的对象不是一回事,JSON 中对象格式更加严格,比如说在 JSON 中属性值不能为函数,不能出现 NaN 这样的属性值等,因此大多数的 js 对象是不符合 JSON 对象的格式的。
- JSON.Stringify(要转换的数据):将json数据转换成字符串json数据
- JSON.parse(要转换的数据):将字符串json数据转成真正的json数据
<script>
var obj = {
"name":"张三",
"age":20
}
/*
JSON.Stringify(要转换的数据):将json数据转换成字符串json数据
JSON.parse(要转换的数据):将字符串json数据转成真正的json数据
*/
var res = JSON.stringify(obj);
console.log(res);//"{"name":"张三","age":20}"
var res1 = JSON.parse(res);
console.log(res1);//{"name":"张三","age":20}
</script>
2.本地存储(localStorage、sessionStorage)
- 存储方法有3种:cookie localStorage sessionStorage
- cookie:多用于服务器存储
- localStorage和sessionStorage都是本地存储 存储到浏览器端
- localStorage:长期存储,除非手动删除,否者会一直存在
- 设置存储信息:localStorage.setItem(key,data)
- 获取存储信息:localStorage.getItem(key)
- 删除单个存储信息 localStorage.removeItem(key);
- 清除所有缓存信息 localStorage.clear()
- sessionStorage:会话存储,当前窗口(会话)关闭 数据就会清除
- 语法和localStorage的用法一致,只需要将localStorage缓存SessionStorage即可
注意:存储数据是键值对的形式存储 存储的格式都是字符串
//存储
localStorage.setItem("name","张三");
localStorage.setItem("age",20);
localStorage.setItem("isLogin",true)
var obj = {
"name":"李四",
"age":18
}
// 如果是json数据存储 需要先用JSON.stringify转换成字符串形式
localStorage.setItem("obj1",JSON.stringify( obj ) )
// 获取
console.log( localStorage.getItem("age") );//"20" string类型
console.log( localStorage.getItem("isLogin") )// "true"
var res = localStorage.getItem("obj1")
console.log( JSON.parse(res) ); //{"name":"李四","age":18}
// 删除
localStorage.removeItem("user");
// 手动清空
localStorage.clear();
3.audio的属性、事件、方法
3.1属性
- src 设置获取音频资源路径
- controls 是否显示标签 true/false
- muted 是否静音 true/false
- loop 是否循环播放 true/false
- autoplay 音频是否自动播放 true/false 不是所有的浏览器都有效果
- currentSrc 只读属性 获取音频资源地址
- currentTime 获取当前播放时长
- volume 获取设置音频的音量 范围[0,1]
- pasued 音频是否停止播放 true暂停 false播放
- ended 音频是否结束播放 true结束 false没有结束
- playbackRate 获取设置音频速度
// 1.属性
// src 设置获取音频资源路径
audio.src = "./source/hanmai.mp3";
// controls 是否显示标签 true/false
audio.controls = true;
// muted 是否静音 true/false
audio.muted = false;
// loop 是否循环播放 true/false
audio.loop = false;
// autoplay 音频是否自动播放 true/false 不是所有的都有效果
audio.autoplay = true;
btn[0].onclick = function () {
// currentSrc 只读属性 获取音频资源地址
console.log(audio.currentSrc);
// currentTime 获取当前播放时长
console.log(audio.currentTime);
// duration 获取音频的总时长
console.log(audio.duration)
// volume 获取设置音频的音量 范围[0,1]
console.log(audio.volume)
// pasued 音频是否停止播放 true暂停 false播放
console.log(audio.paused)
// ended 音频是否结束播放 true结束 false没有结束
console.log(audio.ended);
// playbackRate 获取设置音频速度
console.log(audio.playbackRate)
audio.playbackRate = 3;
}
3.2事件
- oncanplay 开始准备播放音频的时候触发
- onpause 点击播放暂停按钮触发
- onended 音频颁发给结束触发
- ontimeupdate 播放时间更新触发
// 2.事件 有自己的触发场景
// oncanplay 开始准备播放音频的时候
audio.oncanplay = function () {
console.log("开始准备");
}
// onpause 点击播放按钮
audio.onpause = function () {
console.log("播放")
}
// onended 结束
audio.onended = function () {
console.log("结束")
}
// ontimeupdate 时间更新
audio.ontimeupdate = function () {
console.log("正在播放音频")
}
3.3方法
- audio.play();//播放
- audio.pause();//暂停
- audio.load();//重新加载
// 3.方法 主动触发某个功能
btn[1].onclick = function () {
// console.log(123);
audio.play();//播放
audio.pause();//暂停
audio.load();//重新加载
}
4.video的属性、事件、方法
4.1属性
- src 设置获取视频资源路径
- poster 设置视频封面
- width/height 设置视频宽高
- controls 是否显示标签 true/false
- muted 是否静音 true/false
- loop 是否循环播放 true/false
- autoplay 视频是否自动播放 true/false 不是所有的浏览器都有效果
- currentSrc 只读属性 获取视频资源地址
- currentTime 获取当前播放时长
- volume 获取设置视频的音量 范围[0,1]
- pasued 视频是否停止播放 true暂停 false播放
- ended 视频是否结束播放 true结束 false没有结束
- playbackRate 获取设置视频速度
4.2事件
- oncanplay 开始准备播放音频的时候触发
- onpause 点击播放暂停按钮触发
- onended 音频颁发给结束触发
- ontimeupdate 播放时间更新触发
4.3方法
- video.play();//播放
- video.pause();//暂停
- video.load();//重新加载