前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript学习笔记031-本地存储0jsonp

JavaScript学习笔记031-本地存储0jsonp

作者头像
Mr. 柳上原
发布2018-12-14 15:16:03
4840
发布2018-12-14 15:16:03
举报

Author:Mr.柳上原

  • 付出不亚于任何的努力
  • 愿我们所有的努力,都不会被生活辜负
  • 不忘初心,方得始终

能把爱好和工作结合起来

是一件幸福的事情

经过这么多年的挫折

还好现在找到了

前端

我很爱你!

工作

我很爱你!

代码语言:javascript
复制
<meta charset="utf-8">

<!DOCTYPE html> <!-- 文档类型:标准html文档 -->

<html lang='en'> <!-- html根标签 翻译文字:英文 -->

<head> <!-- 网页头部 -->

<meat charset='UTF-8'/> <!-- 网页字符编码 -->

<meat name='Keywords' content='关键词1,关键词2'/>

<meat name='Description' content='网站说明'/>

<meat name='Author' content='作者'/>

<title>前端59期学员作业</title> <!-- 网页标题 -->

<link rel='stylesheet' type='text/css' href='css/css1.css'/> <!-- 外链样式表 -->

<style type='text/css'> /*内部样式表*/

</style>

</head>

<body> <!-- 网页主干:可视化区域 -->

<script>

/*

本地存储:

localStorage 永久存储

sessionStorage 浏览器关闭时清空

*/

// localStorage

// 设置localStorage的值

localStorage.setItem("fengyu", "dashuaibi"); // 参数为key,value,参数只能传字符串形式

// 本地存储查找

Application -> Storage

// 本地存储实例

// 电子记事本

.done{} // 数据的css样式

// 设计可遍历的数据结构

[

{

content: "", // 内容

done: false // 状态

}

]

const ipt = document.getElementById("ipt"); // 输入表单

const list = document.getElementById("list"); // 输出备忘栏(<ul>)

const data = localStorage.getItem("todolist"); // 查询本地存储

// 判断是否有值

if (data === null){ // 没有写入数据时

localStorage.setItem("todolist", "[]"); // 设置本地存储的参数

} else { // 有数据时

JSON.parse(data).forEach((v, i, self) => {

list.innerHTML += `<li class=${v.done ? "done" : ""}>${v.content}<span>X</span></li>`

})

}

// 回车添加内容

ipt.onkeydown = function (e){

// 判断键盘的键值

if (e.keyCode !== 13) return;

// 回车后获取输入的值

const val = this.value.trim();

// 判断输入的内容

if (!val) return;

// 添加数据

const data = JSON.parse(localStorage.getItem("todolist")); // 防止数据覆盖,先取出之前的数据,然后再加上现有写入的数据

list.inneHTML += `<li>${val}<span>X</span></li>`

// 更新本地存储

data.push({

content,

done: false

});

// 写入本地存储

localStorage.setItem("todolist", JSON.stringify(data));

// 清空输入框

this.value = "";

}

// 删除数据事件

list.addEventListener("click", e => {

const that = e.target;

const data = localStorage.getItem("todolist");

e.stopPropagation();

const tagName = that.tagName.toLowerCase();

switch (tagName){

case "span":

data.forEach(function(v, i, self){

if (this === list.children[i]){

list.removeChild(this);

self.splie(i, 1);

}

}, that.parentNode); // forEach回调函数的this指向

break;

case "li":

data.forEach(function(v, i, self){

if (that === list.children[i]){

v.done = !v.done;

that.classlist.toggle("done");

}

})

break;

// 没有default

}

localStorage.setItem("todolist", JSON.stringify(data));

});

/*

jsonp:

json的一种使用模式

跨域获取数据的方式

script的src属性具有跨域请求资源的能力

scr与json配合的模式就是就是jsonp

*/

// src默认get请求

// src里网站的查询字段里输出cb的值

// 后端拿到cb值,返回相应的值名与数据

src="[http://www.xxx.com?username=fengyu&cb=fy](http://www.baidu.com?username=fengyu&cb=fy)"

cb=fy

const cb = ctx.query.cb; // nodejs后端查询命名

ctx.type = "text/javascript";

ctx.body = `${cb}({a: "这是后端朋友传过来的数据"})`;

fy({

JSON: "后端返回的数据"

}) // 格式

// 前端定义一个fy函数,就能取到后端发来的值

function fy(obj){

console.log(obj); // obj = {a: "这是后端朋友传过来的数据"};

}

// 如果当前端需要触发某些方法时再拿到数据

document.onclick = function (){ // 点击事件触发时创建script标签进行跨域操作

const script = document.createElement("script");

script.src = "[http://www.xxx.com?username=fengyu&cb=fy](http://www.baidu.com?username=fengyu&cb=fy)";

document.body.appendChild(script);

}

</script>

// script的src属性

<script src="[http://www.xxx.com?username=fengyu&cb=fy](http://www.baidu.com?username=fengyu&cb=fy)"></script>

</body>

</html>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.11.21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档