专栏首页菜鸟前端工程师JavaScript学习笔记031-本地存储0jsonp

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 条评论
登录 后参与评论

相关文章

  • html+css学习笔记019-H5响应式布局0自适应布局

    Mr. 柳上原
  • html+css学习笔记020-结业(静态网站布局-京东)

    Mr. 柳上原
  • react-开发经验分享-Select选择框表单实现异步省市联动

    Mr. 柳上原
  • 企业面试题: LocalStorage本地存储在HTML5中如何使用

    LocalStores 本地存储就是一个轻量级的sqllite数据库。可以在客户端本地存储数据,用于在断开网络连接的情况下读取本地缓存cookies,Local...

    舒克
  • WebStorage是什么?

    使用HTML5可以在本地存储用户的浏览数据。早些时候,本地存储使用的是 cookie。但是Web 存储需要更加的安全与快速,这些数据不会被保存在服务器上,但是这...

    飞狗
  • ICCV 2019 | 一种基于卷积神经网络的驾驶员和安全带检测的灵活体系结构

    作者 | BBuf 单位 | 北京鼎汉技术有限公司 算法工程师(CV) 编辑 | 唐里

    AI科技评论
  • JavaScript强化教程——sessionStorage和localStorage

    本文作者:IMWeb 王军 原文出处:IMWeb社区 未经同意,禁止转载 本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScr...

    IMWeb前端团队
  • JavaScript强化教程——sessionStorage和localStorage

    本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 —— sessionStorage和localStorage

    IMWeb前端团队
  • 一日一技:单机单节点 MongoDB 为什么删除数据后不释放空间?

    MongoDB 3.6以后,默认使用的储存引擎是 WiredTiger。这个引擎有一个特点,就是删除数据不释放空间。例如现在你的一个集合里面有10000000条...

    青南
  • springcloud zuul的跨域问题

    正常情况下,跨域是这样的:  1. 微服务配置跨域+zuul不配置=有跨域问题  2. 微服务配置+zuul配置=有跨域问题  3. 微服务不配置+zuul不配...

    似水的流年

扫码关注云+社区

领取腾讯云代金券