第一个react项目

出错的地方都注释起来了,有时间总结一下错误原因及处理方法

/*
window.localStorage.person=JSON.stringify([
    { "name": "张大明", "age":"17", "sex": "男" ,"picture":"./img/boy.jpg"},

    { "name": "李凯", "age":"20", "sex": "男","picture":"./img/boy2.jpg"},

    {  "name": "王小源", "age":"14", "sex": "女","picture":"./img/girl.jpg" },

    {  "name": "赵小云", "age":"14", "sex": "女","picture":"./img/girl2.jpg" }]);

var temp=JSON.parse(window.localStorage.person);
console.log(temp);
temp.push({"name":"user_name","age":"user_name","sex":"user_name","picture":"user_name"});
console.log(temp);
window.localStorage.person=JSON.stringify(temp);
*/
//判断是否支持localstroge
if(window.localStorage){
    //如果不存在已经初始化过的存储用户信息的变量,则执行初始化操作
    if(!window.localStorage.getItem('userInfo'))
    {
        //默认用户数据
        window.localStorage.userInfo=JSON.stringify([
            { "name": "张大明", "age":"17", "sex": "男" ,"picture":"./img/boy.jpg"},

            { "name": "李凯", "age":"20", "sex": "男","picture":"./img/boy2.jpg"},

            {  "name": "王小源", "age":"14", "sex": "女","picture":"./img/girl.jpg" },

            {  "name": "赵小云", "age":"14", "sex": "女","picture":"./img/girl2.jpg" }
        ]);
    }
    //刷新页面后,新添加的数据丢失的原因:
    //每次重新打开页面都会执行默认初始化动作,所以改变的数据都会被初始化数据覆盖
}else{
    alert('This browser does NOT support localStorage');
}
var dateAry=localStorage.getItem("userInfo");
dateAry=JSON.parse(dateAry);
//建一个组件
var UserList = React.createClass({
    //显示详细信息
   showClick:function(event){
       var ul=this.refs.tip;
       var target=event.target;
       var detail=null;
       if(target.tagName.toLowerCase() == 'div'){
            detail=target.parentNode.childNodes[1];
           if(detail.style.display=="block"){
               detail.style.display='none';
           }else{
               detail.style.display='block';
           }
       }else if(target.tagName.toLowerCase() == 'img'&& target.className.toLowerCase() == 'expand_img'){
           detail=target.parentNode.parentNode.nextSibling;
           if(detail.style.display=="block"){
               detail.style.display='none';
           }else{
               detail.style.display='block';
           }
       }
       /*if(detail.style.display=="block"){
           detail.style.display='none';
       }else{
           detail.style.display='block';
       }*/
       event.stopPropagation();
       event.preventDefault();
       /* var tips=this.refs.tip.getElementsByTagName("li");
         for(let i=0;i<dateAry.length;i++){
             tips[i].onclick=function(event){

                 var tip=this.getElementsByTagName("div")[1];
               if(tip.style.display=="none"){
                     tip.style.display='block';
                 }else{
                     tip.style.display='none';
                 }
                /!* var a=tip.style.display="none";
                 var b=tip.style.display='block';
                 tip.style.display=="none"?b:a;*!/
                 event.stopPropagation();
                 event.preventDefault();
            }
         }*/
    },
    //增加用户信息的按钮:实现表单的显示和隐藏
    addClick:function(event){
     var add_btn=this.refs.add;
        if(add_btn.style.display=="block"){
            add_btn.style.display='none';
        }else{
            add_btn.style.display='block';
        }
        event.stopPropagation();
        event.preventDefault();
    },
    //保存用户信息:把用户的信息收集起来进行本地存储并显示到页面上
saveClick:function(){
    var submit=document.getElementById("sub");
    var user_name=document.getElementsByName("name")[0].value;
    var user_age=document.getElementsByName("age")[0].value;
    var user_sex=document.getElementsByName("sex")[0].value;
    //var user_img=document.getElementsByName("picture")[0].files[0];

    if(window.FileReader){

            var file = document.getElementById('file').files[0];
            if (file) {
                var reader = new FileReader();
                reader.readAsDataURL(file);
                reader.onloadend = function ( event ) {
                    var user_img = event.target.result;
                    if(user_name==""||user_age==""||user_sex==""||user_img==""){
                        alert("所有输入不能为空");
                    }
                    else{
                        var add_info={"name":user_name,"age":user_age,"sex":user_sex,"picture":user_img};
                        var temp=JSON.parse(window.localStorage.getItem('userInfo'));
                        temp.push(add_info);
                        dateAry=temp;
                        //信息存储到本地存储
                        window.localStorage.setItem('userInfo',JSON.stringify(temp));
                        //测试存储信息
                        console.log(window.localStorage.getItem('userInfo'));
                        //刷新页面显示最新数据
                        window.location.reload(true);
                    }
                };
            }


    }else{
        alert(" Not supported by your browser");
    }



/*if(user_name==""||user_age==""||user_sex==""||user_img==""){
    alert("所有输入不能为空");
}
    else{
    var add_info={"name":user_name,"age":user_age,"sex":user_sex,"picture":user_img};
    var temp=JSON.parse(window.localStorage.getItem('userInfo'));
    temp.push(add_info);
    dateAry=temp;
    //信息存储到本地存储
    window.localStorage.setItem('userInfo',JSON.stringify(temp));
    //测试存储信息
    console.log(window.localStorage.getItem('userInfo'));
    //刷新页面显示最新数据
    window.location.reload(true);
}*/
},

    //删除用户信息:通过点击删除按钮删除某个用户信息
   deleteClick: function (event) {
       var deleteInfo=event.target.parentNode.parentNode.childNodes[0].innerText;
      // console.log(deleteInfo);

       var items=JSON.parse(window.localStorage.getItem('userInfo'));
       for(var i=0;i<items.length;i++){
           if(items[i].name==deleteInfo){
               items.splice(i,1);
               var newInfo=JSON.stringify(items);
               window.localStorage.setItem('userInfo',newInfo);
               window.location.reload(true);
           }
       }

       /*for(var i=0;i<items.length;i++){

      }*/

   },
        render: function() {
        var newArr = [];
        for (var i=0;i<dateAry.length;i++){
             var item=dateAry[i];
             newArr.push(<li className="item">
                 <div className="summary" ><sapn className="name">{item.name}</sapn> <span className="img_box"><img  onClick={this.deleteClick.bind(this)} src="./img/delete.jpg"/><img className="expand_img" src="./img/expand.jpg"/></span></div>
                 <div className="detail" ><div className="picture"><span ><img className="head_img" src={item.picture}/></span></div><div className="describe"><span>性别:{item.sex}</span><span>年龄:{item.age}</span></div></div>
             </li>);
        }
        return (<div className="container"><ul className="list" ref="tip"  onClick={this.showClick.bind(this)}>{newArr}</ul>
        <div className="add_container" >
            <div><button id="add_btn"  onClick={this.addClick.bind(this)}> 新增用户</button></div>
            <form id="add" ref="add">
                <label>姓名:</label> <input type="text" name="name" required="required" /><br/><br/>
                <label>年龄:</label>  <input type="text" name="age" required="required" /><br/><br/>
                <label>性别:</label>  <input type="text" name="sex" required="required" /><br/><br/>
                <label>上传头像图片:</label>  <input type="file" id="file"  name="picture" required="required"  accept="image/gif, image/jpeg"/><br/><br/>
                <input id="sub" type="button" value="确定提交" onClick={this.saveClick.bind(this)}/>
            </form>
        </div>
        </div>);
    }
});


ReactDOM.render(
    <UserList />,
    document.getElementById('app')
);

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容