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

Author:Mr.柳上原

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

能把爱好和工作结合起来

是一件幸福的事情

经过这么多年的挫折

还好现在找到了

前端

我很爱你!

工作

我很爱你!

<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>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏闻道于事

动态增加表单元素并获取元素的text和value提交

以上是效果图 需求是这样的: 专家设置好条件,然后设备检测到达到相应的条件之后,设备发出提醒给用户。 这就需要专家设置好能看懂的条件之后,然后把给专家看的,正常...

71111
来自专栏雨过天晴

原 荐 C# FTP 坑了我两天的一个坑

1.3K6
来自专栏前端开发

so easy 前端实现多语言

3206
来自专栏非著名程序员

常见面试第四题之requestLayout, invalidate和postInvalidate的异同

requestLayout, invalidate和postInvalidate的异同 ? 今天我们来讲讲在面试当中最常见的,最常常被问到的第四题,近期由于小...

2585
来自专栏用户2442861的专栏

Java Web 中使用ffmpeg实现视频转码、视频截图,javaffmpeg

http://www.cnblogs.com/dennisit/archive/2013/02/16/2913287.html#!comments

6231
来自专栏AhDung

【VBS】vbs指定编码保存文本文件(含xml、ini什么的)

- 让用户填写一些信息,待安装完成后把这些信息写入软件安装目录中的指定ini、xml文件中

1121
来自专栏Spring相关

Vue把父组件的方法传递给子组件调用(评论列表例子)

2352
来自专栏IMWeb前端团队

用原生js写一个"多动症"的简历

用原生js写一个"多动症"的简历 预览地址 源码地址 最近在知乎上看到@方应杭用vue写了一个会动的简历,觉得挺好玩的,研究一下其实现思路,决定试试用原生js...

4407
来自专栏我的小碗汤

爬取珍爱网后用户信息展示

golang爬取珍爱网,爬到了3万多用户信息,并存到了elasticsearch中,如下图,查询到了3万多用户信息。

2074
来自专栏TungHsu

【干货】什么?Python3.X不能输出中文?原来是编辑器geany的锅?!

小白说我要开始学Python了,既然3.X支持中文,那就学3吧。于是安装好Python环境,下载好geany就开始写了。 先写个“Hello World”吧,作...

4606

扫码关注云+社区

领取腾讯云代金券