liuyan
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
#div1{
width: 400px;
height: 200px;
overflow:auto;
border: #000000 1px solid;
}
</style>
</head>
<body>
<div id="div1">
<ul id="ul1"></ul>
</div>
<input type="text" id="input1" />
<input type="button" id="btn" value="留言" />
<script type="text/javascript" src="cookie.js" ></script>
<script>
btn.onclick = function(){
// 输入框的内容
var str = input1.value;
input1.value = "";
// 防止xss攻击
str = str.replace(/</g,'<'); // /</ 表示正则对象,g表示全局匹配
str = str.replace(/>/g,'>'); // 语义为,在当前的str中,全局查找>,替换成>
// 创建li,显示在ul中
var li = document.createElement("li");
ul1.appendChild(li);
li.innerHTML = str;
//li.innerText = str;
// 用cookie将str数据存储起来
// 先把原始数据取出来
// 第一次获取data这个cookie时,r拿到的时undefined
var r = getCookie("data"); // r='[str1, str2....]'
var arr;
if( r ){ // 如果存在原始数据的话,把原始数字这个字符串,转换为数组对象
arr = JSON.parse(r); // arr = JSON.parse('[str1, str2....]')
}else{ // 如果不存在原始数据时,即第一次添加数据,所以arr是空数组
arr = [];
}
arr.push(str); // 把当前输入框中的值,追加存储到数组中
// 把数组,转换为字符串后,保存到cookie中
var jsonstr = JSON.stringify(arr);
setCookie("data", jsonstr, 7);
} // 打开页面时,把data,显示到ul中
var r = getCookie("data");
if( r ){ // 如果存在数据
// 把字符串转换为数组
var arr = JSON.parse(r);
// 循环
for( var i=0,len=arr.length; i<len; i++ ){
var li = document.createElement("li");
ul1.appendChild(li);
li.innerHTML = arr[i];
}
}else{
// 如果不存在数据
} </script>
</body>
</html>function setCookie( cookieName, cookieValue, d, path ){
var str = cookieName+"="+ encodeURIComponent(cookieValue);//编码
if( d ){ // 如果设置了过期时间
var dt = new Date();
dt.setDate( dt.getDate()+d );
str += ";expires="+dt.toGMTString();
}
if( path ){ // 如果设置了path属性
str += ";path="+path;
}
document.cookie = str;
}
function getCookie( cookieName ){
var str = decodeURIComponent(document.cookie);//解码
var arr = str.split("; "); // 注意根据分号和空格拆分
for( var i=0,len=arr.length; i<len; i++ ){
var c = arr[i].split("=");
if( c[0]==cookieName ){
// return c[1];// 前提是,所设置的cookie内容中没有等号
// 如果cookie中存在等号的话,截取的是第一个等号后面的所有数据
return arr[i].substr(cookieName.length+1)
}
}
}
liuyan的更多相关文章
- JavaScript进阶之路(一)初学者的开始
一:写在前面的问题和话 一个javascript初学者的进阶之路! 背景:3年后端(ASP.NET)工作经验,javascript水平一般般,前端水平一般般.学习资料:犀牛书. 如有误导,或者错误的地 ...
- AngularJs学习笔记(制作留言板)
原文地址:http://www.jmingzi.cn/?post=13 初学Anjularjs两天了,一边学一边写的留言板,只有一级回复嵌套.演示地址 这里总结一下学习的过程和笔记.另外,看看这篇文章 ...
- laravel数据库迁移(三)
laravel号称世界上最好的框架,数据库迁移算上一个,在这里先简单入个门: laravel很强大,它把表中的操作写成了migrations迁移文件,然后可以直接通过迁移文件来操作表.所以 , 数据迁 ...
- tp框架之留言板练习
登陆控制器与显示页面 <?php namespace Admin\Controller; use Think\Controller; class DengController extends C ...
- 从零开始编写属于我的CMS:(六)插件
二三四五还没写,先写六吧(有道友说想看看插件部分). 这里是一 从零开始编写属于我的CMS:(一)前言 一,首先预定义接口 新建类库,WangCms.PluginInterface 新建两个类,一个实 ...
- 11月8日PHP练习《留言板》
一.要求 二.示例页面 三.网页代码及网页显示 1.denglu.php 登录页面 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tran ...
- R语言 ETL+统计+可视化
这篇文章...还是看文章吧 导入QQ群信息,进行ETL,将其规范化 计算哪些QQ发言较多 计算一天中哪些时段发言较多 计算统计内所有天的日发言量 setwd("C:/Users/liyi/D ...
- thinkphp留言板例子(多条件查询)
登录: login.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "htt ...
- 2 . Linux常见命令
Linux常见命令格式: 命令名称 选项 参数 ls -alh 文件/目录 --all #ls 显示当前目录内容 #ls -l 显示文件详细信息 #ls -hl h已常见单位显示文件大小 k M G# ...
随机推荐
- 用PHP的curl实现并发请求远程文件(并发抓取远程网页)
PHP的curl功能确实强大了.里面有个curl_multi_init功能,就是批量处理任务.可以利用此,实现多进程同步抓取多条记录,优化普通的网页抓取程序. 一个简单的抓取函数: function ...
- Excel各种条件求和的公式汇总
经常和Execl打交道的人肯定觉得求和公式是大家时常用到的.Excel里有哪几路求和公式呢?他们的使用方式又是怎样?我为大家汇总一下. 使用SUMIF()公式的单条件求和: 如要统计C列中的数据,要求 ...
- php递归无限级
function getTree($data, $pId) { $tree = ''; foreach($data as $k => $v) { if($v['cate_ParentId'] = ...
- PHP开发api接口安全验证方法一
前台想要调用接口,需要使用几个参数生成签名.时间戳:当前时间随机数:随机生成的随机数 签名:特定方法生成的sign签名 算法规则在前后台交互中,算法规则是非常重要的,前后台都要通过算法规则计算出签名, ...
- CNTA-2019-0014 wls9-async 反序列化 rce 分析
在调试weblogic,以前导入jar包都是在weblogic目录搜索*.jar拷贝出来在导入IDEA.有时候会出现好多相同的jar包,调试的时候就会出问题,实际上导入以下俩个包就可以了.1.是mod ...
- FFMPEG详细参数
这几天做视频相关的东西,找到了这款比较牛掰的工具FFmpeg Howto Table of Contents * Generic Syntax * Main Options * Encoding : ...
- 20145203盖泽双 《网络对抗技术》实践九:Web安全基础实践
20145203盖泽双 <网络对抗技术>实践九:Web安全基础实践 1.实践目标 1.理解常用网络攻击技术的基本原理. 2.Webgoat下进行相关实验:SQL注入攻击.XSS攻击.CSR ...
- ActiveMQ安装配置及使用
ActiveMQ介绍 ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管J ...
- ORA-600 [Kcbz_check_objd_typ_1] Running a Job (Doc ID 785899.1)
ORA-600 [Kcbz_check_objd_typ_1] Running a Job (Doc ID 785899.1) To Bottom In this Document Symptom ...
- Java中try catch finally语句中含有return语句的执行情况(总结版)
在这里看到了try >但有一点是可以肯定的,finally块中的内容会先于try中的return语句执行,如果finall语句块中也有return语句的话,那么直接从finally中返回了,这也 ...