码迷,mamicode.com
首页 > Web开发 > 详细

关于html5 通讯录功能

时间:2015-02-05 13:51:12      阅读:235      评论:0      收藏:0      [点我收藏+]

标签:

我们手机端的通讯录是用的技术html5 sqlite 加上jquery 实现单机缓存功能 头像是用base 64 进行渲染


/*************************************/  
    /* Helman, heldes.com      */  
    /* helman at heldes dot com    */  
    /* sqlitedb.js           */  
    /* SQLite Database Class For HTML5 */  
    /*************************************/  
      
    function cDB(confs){  
      var ret = {  
        _db: null,  
        _response: null,  
        _error: null,  
        check : function(tbl){  
          if(!this._db) return false;  
          var _sql = ‘‘, _sqlField=‘‘, _field=[];  
       
          for(var i=0;i<tbl.length;i++){  
            _sql = "CREATE TABLE IF NOT EXISTS "+tbl[i].table+" (";  
            _field = tbl[i].properties;  
            _sqlField = ‘‘;  
       
            for (var j=0;j<_field.length;j++){  
              _sqlField += ‘,`‘+_field[j].name+‘` ‘+_field[j].type;  
            }  
       
            _sql += _sqlField.substr(1)+");";  
       
            this.query(_sql,null,null,null);  
          }  
       
          return true;  
        },  
        getResult:function(){  
          return this._response;  
        },  
        getError:function(){  
          return this._error;  
        },  
        callback_error: function(tx,_er){  
          var err = ‘‘;  
          if(typeof(tx) == ‘object‘){  
            for(var q in tx){  
              err += q+‘ = "‘+tx[q]+‘"; ‘;  
            }  
          }else{  
            err += tx+‘; ‘;  
          }  
          if(typeof(_er) == ‘object‘){  
            for(var q in _er){  
              err += q+‘ = "‘+_er[q]+‘"; ‘;  
            }  
          }else if(typeof(_er) == ‘undefined‘){  
            err += _er+‘; ‘;  
          }  
          console.log(err);  
          //if(callback) callback();  
          return false;  
        },  
        query: function(sql,callback,params,er){  
          if(!this._db) return false;  
          var self = this;  
          function _er(tx,__er){  
            __er = jQuery.extend(__er,{sql:sql});  
            if(er) er(tx,__er);  
            else self.callback_error(tx,__er);  
          };  
          this._db.transaction(function(tx){  
            tx.executeSql(sql,(params?params:[]),callback,_er);  
          }, _er);  
        },  
        update:function(tbl,sets,clauses,callback){  
          var __sql = ‘UPDATE ‘+tbl, _field = null, __set = ‘‘, __clause = ‘‘,__values=[];  
       
          for(var i=0;i<sets.length;i++){0  
            _field = sets[i];  
            for(var j=0;j<_field.length;j++){  
              __set += ‘,`‘+_field[j].name+‘`=?‘;  
              __values.push(_field[j].value);  
            }  
          }  
       
          for(var i=0;i<clauses.length;i++){  
            __clause += ‘,`‘+clauses[i].name+‘`=?‘;  
            __values.push(clauses[i].value);  
          }  
          __sql += ((__set!=‘‘)?‘ SET ‘+__set.substr(1):‘‘)+((__clause!=‘‘)?‘ WHERE ‘+__clause.substr(1):‘‘)+‘;‘;  
          this.query(__sql,callback,__values);  
          return true;  
        },  
        remove:function(tbl,clauses){  
          var __sql = ‘DELETE FROM ‘+tbl, __clause = ‘‘;  
       
          for(var i=0;i<clauses.length;i++)  
            __clause += ‘,`‘+clauses[i].name+‘`="‘+escape(clauses[i].value)+‘"‘;  
       
          __sql += ‘ WHERE ‘+((__clause!=‘‘)?__clause.substr(1):‘FALSE‘)+‘;‘;  
       
          this.query(__sql);  
          return true;  
        },  
        multiInsert: function(tbl,rows,callback,er){  
          if(!this._db) return false;  
          var self = this;  
          var __sql = ‘‘, _field = null, __field = ‘‘, __qs = [], __values = [];  
       
          this._db.transaction(function(tx){  
            for(var i=0;i<rows.length;i++){  
              __qs = [];  
              __values = [];  
              __field = ‘‘;  
              _field = rows[i];  
       
              for(var j=0;j<_field.length;j++){  
                __field += ‘,`‘+_field[j].name+‘`‘;  
                __qs.push(‘?‘);  
                __values.push(_field[j].value);  
              }  
              tx.executeSql(‘INSERT INTO ‘+tbl+‘ (‘+__field.substr(1)+‘) VALUES(‘+__qs.join(‘,‘)+‘);‘,__values,function(){return false;},(er ? er : self.callback_error));  
            }  
          }, self.callback_error, function(){  
            if(callback) callback();  
            return true;  
          });  
          return true;  
        },  
        insert:function(tbl,rows,callback){  
          var __sql = ‘‘, _field = null, __field = ‘‘, __qs = [], __values = [], __debug = ‘‘;  
       
          for(var i=0;i<rows.length;i++){  
            __qs = [];  
            __field = ‘‘;  
            _field = rows[i];  
       
            __debug += _field[0].name+‘ = ‘+_field[0].value+‘;‘;  
            for(var j=0;j<_field.length;j++){  
              __field += ‘,`‘+_field[j].name+‘`‘;  
              __qs.push(‘?‘);  
              __values.push(_field[j].value);  
            }  
            __sql += ‘INSERT INTO ‘+tbl+‘ (‘+__field.substr(1)+‘) VALUES(‘+__qs.join(‘,‘)+‘);‘;  
          }  
          this.query(__sql,callback,__values);  
          return true;  
        },  
        insertReplace:function(tbl,rows,debug){  
          var __sql = ‘‘, _field = null, __field = ‘‘, __qs = [], __values = [], __debug = ‘‘;  
       
          for(var i=0;i<rows.length;i++){  
            __qs = [];  
            __field = ‘‘;  
            _field = rows[i];  
       
            __debug += _field[0].name+‘ = ‘+_field[0].value+‘;‘;  
            for(var j=0;j<_field.length;j++){  
              __field += ‘,`‘+_field[j].name+‘`‘;  
              __qs.push(‘?‘);  
              __values.push(_field[j].value);  
            }  
            __sql += ‘INSERT OR REPLACE INTO ‘+tbl+‘ (‘+__field.substr(1)+‘) VALUES(‘+__qs.join(‘,‘)+‘);‘;  
          }  
          this.query(__sql,null,__values);  
          return true;  
        },  
        dropTable:function(tbl,callback){  
          var __sql = ‘‘;  
          if(tbl==null) return false;  
          __sql = ‘DROP TABLE IF EXISTS ‘+tbl;  
          this.query(__sql,callback);  
          return true;  
        }  
      }  
      return jQuery.extend(ret,confs);  
    }
这个是sqlite 基本crud代码


输入框搜索 执行代码

<input class="search-input ub ub-f1" id="search_" oninput="OnInput()" placeholder=" "/>


初始化sqlite数据库持久化脚本


db : new cDB({_db:window.openDatabase("websiteDB", "", "website DB", 5*1000*1000*10)}),
创建通讯录表接口
dbTable : [  
	        {
	        	table:‘contacat‘,properties: 
	        	[  
	        		//员工编号,主键
	            	{name:‘empSno‘, type: ‘INT PRIMARY KEY ASC‘},
	            	//姓名
	            	{name:‘username‘,type: ‘‘},
	            	//头像
	            	{name:‘imgBase64‘,type: ‘‘},
	            	//部门
					{name:‘deptName‘,type: ‘‘},
					//邮箱
					{name:‘email‘,type: ‘‘},
					//手机号
					{name:‘mp‘,type: ‘‘},
					//职位
					{name:‘positionName‘,type: ‘‘},
					//公司号码
					{name:‘companySno‘, type: ‘‘} ,
					{name:‘positionNameEn‘, type: ‘‘}  ,
					{name:‘deptNameEn‘,type: ‘‘}
	        	]
	        }
	    ],
modifyTable :
        [  
            {
                table:‘modifyTimeTable‘,properties: 
                [  
                    {name:‘companySno‘, type: ‘‘},  
                    {name:‘modifyTime‘, type: ‘‘}
                ]
            }
        ],
        modifyDate:"",
        isGetService:true,
        loadDataFlag:true,
        reloadData:function(){
            //先清空列表
            $("#list").html("")
            //清空搜索框
            $("#search_").val("")
            //开始重新同步
            contact.isGetService=false;
            //设置第一次同步
            setstorage("isCacheContrat",null);
            //变量控制
            contact.isInit=null;
            //获取数据
            contact.initData();    
        },





每次点击同步操作 检查网络 如果是3G情况下提示 每次更新仅仅更新修改过的数据



reData:function(){
			if(!contact.isGetService){
				msgPrompt(getLang("contactWaiting"));
				return false;
			}
			uexDevice.getInfo(‘13‘);
			
			uexDevice.cbGetInfo = function(opCode, dataType, data)
			{
				//获取手机返回字符串,转换json
				var device = eval(‘(‘ + data + ‘)‘);
				var connectStatus=device.connectStatus;
					//判断当前网络情况
					if(connectStatus!=null&&connectStatus.length>0)
					{
						//网络不可用返回connectionstatus=1 wifi情况下返回0 connectionstatus1或者是conectionstatus=2是3g或者2g
						if(connectStatus==-1)
						{
							//网络不可能用提示操作
							msgPrompt(getLang("wlbukeyong"));
							return;	
						}else if(connectStatus==0)
						{
							//wifi情况直接同步
							contact.reloadData()
						}else if(connectStatus==1 || connectStatus==2)
						{
							//如果对话框进行确定或者取消会触发回调函数
							uexWindow.cbConfirm = function ConfirmSuccess(opId, dataType, data)
							{
								//如果点击确定的话data返回0
				                if (data == 0) 
				                {
				                	//同步数据
									contact.reloadData()
				                }
	           				};
	           				//如果是3g情况进行弹出confirm进行提示
	           				uexWindow.confirm(getLang("sureMsg"), getLang("tongbutishi"), [getLang("sure"), getLang("nosure")]);
						}
					}
			}
			
		},
查询sqlite 代码
//清空列表
			$("#list").html("");
			//渲染操作控制
			if(!contact.loadDataFlag)
			{
					return false;
			}
			contact.loadDataFlag=false;
			var query = "";
			//如果有搜索操作进行追加搜索条件
			if(filter!=null)
			{
				query = ‘SELECT * FROM contacat  where  (username like "%‘+filter
				           +‘%" COLLATE NOCASE or email like "%‘+filter+‘%" COLLATE NOCASE or mp like "%‘
						   +filter+‘%" COLLATE NOCASE  )  and companySno="‘+contact.user.companySno+‘"  order by email asc‘;  
            }
			else
			{
				query = ‘SELECT * FROM contacat  where    companySno="‘+contact.user.companySno+‘"  order by email asc‘; 
			}
			contact.db.query(query,function(tx,res)
			{  
  				if(res.rows.length)
				{  
					//获取数据循环操作
					for (var i = 0; i < res.rows.length; i++)
					{	
						//根据下标进行获取数据
						var result = res.rows.item(i);
						var imgpt = "";
						//如果二进制图片不存在显示默认图片
						if (result.imgBase64 == null || result.imgBase64 == undefined|| result.imgBase64 == "") {
								imgpt = "css/myImg/person.png";
						}
						else 
						{	
							//显示二进制图片
							imgpt = "data:image/gif;base64," + result.imgBase64;
						}
							contact.pullAppend(result, imgpt);
					}
  				}
				contact.loadDataFlag  = true;


因为后台是sass 架构  所以A 的通讯录看不到B通讯录  防止切换账号产生脏数据

//根据companysno查询修改时间 防止切换用户重新加载数据
			var query = "select * from modifyTimeTable where companySno=‘"+contact.user.companySno+"‘";
			//查询操作 进行回调 因为是查询是异步操作所以需要把同步数据放到回调操作
			contact.db.query(query,function(tx,res)
			{
				//如果有数据操作把数据取出来
    			if(res.rows.length)
				{
					//把上次同步时间
					contact.modifyDate = res.rows.item(0).modifyTime;
				}else
				{
					//如果是null表示没有进行同步操作
					contact.modifyDate="";
				}
				//如果是第一次操作或者是修改为空的情况进行同步操作,否则直接从数据库渲染
				if (contact.isInit == null||contact.isInit==""||contact.modifyDate=="") {
					//进度条
					uexWindow.toast(1, 5,getLang("loadContacts"), -1);
					//延迟加载数据
					setTimeout(function(){
					contact.loadGetData();	
					},200);
				}else{
					//渲染加载
					setTimeout(function(){
					contact.insertList(null);
					
					},1000);
				}
刚装机器第一次同步时候    

    


//根据companysno查询修改时间 防止切换用户重新加载数据
			var query = "select * from modifyTimeTable where companySno=‘"+contact.user.companySno+"‘";
			//查询操作 进行回调 因为是查询是异步操作所以需要把同步数据放到回调操作
			contact.db.query(query,function(tx,res)
			{
				//如果有数据操作把数据取出来
    			if(res.rows.length)
				{
					//把上次同步时间
					contact.modifyDate = res.rows.item(0).modifyTime;
				}else
				{
					//如果是null表示没有进行同步操作
					contact.modifyDate="";
				}
				//如果是第一次操作或者是修改为空的情况进行同步操作,否则直接从数据库渲染
				if (contact.isInit == null||contact.isInit==""||contact.modifyDate=="") {
					//进度条
					uexWindow.toast(1, 5,getLang("loadContacts"), -1);
					//延迟加载数据
					setTimeout(function(){
					contact.loadGetData();	
					},200);
				}else{
					//渲染加载
					setTimeout(function(){
					contact.insertList(null);
					
					},1000);
				}
递归请求获取每个用户的头像



//获取完毕进行操作
			if(index>length-1){
				setTimeout(function(){
					contact.isGetService=true;
					//查询最后一次操作事件
					var query = "select * from modifyTimeTable where companySno="+contact.user.companySno;
					contact.db.query(query,function(tx,res)
					{
						var data=
						[
						{
					 		‘name‘: ‘companySno‘,
					 		‘value‘: contact.user.companySno
					 	}, 
						{
					 		‘name‘: ‘modifyTime‘,
					 		‘value‘: new Date().getTime()
					 	}
						]
						//存在进行先删除后插入
    					if(res.rows.length)
						{
							contact.db.remove(‘modifyTimeTable‘, [{
					 					‘name‘: ‘companySno‘,
					 					‘value‘: contact.user.companySno
					 		}]);
						}
						var row = [];
						//存放数据
						row.push(data);
						//进行插入操作
					 	contact.db.insert(‘modifyTimeTable‘, row);
					 	//进行渲染列表
						contact.insertList(null);
						uexWindow.closeToast();
						setstorage("isCacheContrat",123);
					})
					
						
				contact.isInit=123;
			},3000)
				return false;
			}

			var 	empSno = pep[index].empSno
			var url = ApIp + "ManagerDemo/user/empPhotoAction.do?token=" + contact.token + "&empSno=" + empSno+"&index="+index;
			$.ajax({
				url: url,
				data: 
						{
							"userName": contact.user.userName,
							"privilegeGroupId": contact.privilegeGroupId
						},
			
				type: ‘POST‘,
				dataType: "json",
				error: function(){
					contact.getImage(index,pep.length,pep)
				},
				success: function(data)
				{
					 //获取单个头像登录失效
					 if (data.msg == 205) {
					 	//登录失效进行跳转登录页面置空session
					 	uexWindow.toast(1, 5, getLang("loginFail"), 0);
					 	setInterval(function(){
					 		setstorage("sessionId", null);
					 		uexWindow.closeToast();
					 		openNewWin(‘login‘, ‘../login/login.html‘, ‘5‘);
					 		winClose()
					 	}, 2000)
					 }else 
					 {
					 	uexWindow.toast(1, 5, sync1 + (parseInt(data.index) + 1) + sync2 + sync3 + pep.length + sync4, -1);
					 	empSno1 = pep[data.index].empSno
					 	
					 	var query = ‘SELECT * FROM contacat where empSno =‘ + pep[index].empSno;
					 	
					 	contact.db.query(query, function(tx, res){
					 		if (pep[data.index].status == "0") {
					 			contact.db.remove(‘contacat‘, [{
					 				‘name‘: ‘empSno‘,
					 				‘value‘: pep[data.index].empSno
					 			}]);
					 		}
					 		else {
					 			var contactData = 
					 			[
					 				
					 				{‘name‘: ‘empSno‘,‘value‘: pep[data.index].empSno},
					 				{‘name‘: ‘positionName‘,‘value‘: pep[data.index].positionName}, 
					 				{‘name‘: ‘mp‘,‘value‘: pep[data.index].mp},
					 				{‘name‘: ‘email‘,‘value‘: pep[data.index].email},
					 				{‘name‘: ‘deptName‘,‘value‘: pep[data.index].deptName}, 
					 				{‘name‘: ‘username‘,‘value‘: pep[data.index].name},
					 				{‘name‘: ‘companySno‘,‘value‘: pep[data.index].companySno},
					 				{‘name‘: ‘imgBase64‘,‘value‘: data.data},
									{name:‘positionNameEn‘, value: pep[data.index].positionNameEn}  ,
									{name:‘deptNameEn‘,value: pep[data.index].deptNameEn}
					 			]
					 			if (res.rows.length) {
					 				contact.db.remove(‘contacat‘, [{
					 					‘name‘: ‘empSno‘,
					 					‘value‘: pep[data.index].empSno
					 				}]);
					 			}
					 			
					 			var row = [];
					 			row.push(contactData);
					 			contact.db.insert(‘contacat‘, row);
					 		}
							
					 		//下标
					 		index = parseInt(data.index) + 1;
					 		//获取下一个用户的头像
					 		contact.getImage(index, pep.length, pep)
					 		
					 	});
					 }
				},error:function(XMLHttpRequest, textStatus, errorThrown){
							index=index+1;
							contact.getImage(index,pep.length,pep)
				}
			}); 




关于html5 通讯录功能

标签:

原文地址:http://my.oschina.net/u/1261887/blog/375599

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!