当前位置:首页 > 代码 > 正文

HTML5查询功能代码(html5媒体查询)

admin 发布:2022-12-19 19:14 213


今天给各位分享HTML5查询功能代码的知识,其中也会对html5媒体查询进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

HTML5 Web SQL 数据库怎样实现多表查询 ?

HTML5的Web SQL Databases(html5 本地数据库)的确很诱惑人,当你发现可以用与mysql查询一样的查询语句来操作本地数据库时,你会发现这东西挺有趣的。今天,我们一起来了解HTML 5的Web SQL Database API:openDatabase、transaction、executeSql。

Web SQL数据库API实际上不是HTML5规范的组成部分,而是单独的规范。它通过一套API来操纵客户端的数据库。Safari、Chrome、Firefox、Opera等主流浏览器都已经支持Web SQL Database。HTML5的Web SQL Databases的确很诱惑人,当你发现可以用与mysql查询一样的查询语句来操作本地数据库时,你会发现这东西挺有趣的。今天,我们一起来了解HTML 5的Web SQL Database API。

下面将一一将介绍怎样创建打开数据库,创建表,添加数据,更新数据,删除数据,删除表 。

先介绍三个核心方法

1、openDatabase:这个方法使用现有数据库或创建新数据库创建数据库对象。

2、transaction:这个方法允许我们根据情况控制事务提交或回滚。

3、executeSql:这个方法用于执行真实的SQL查询。

第一步:打开连接并创建数据库

代码如下:

var dataBase = openDatabase("student", "1.0", "学生表", 1024 * 1024, function () { });

if (!dataBase) {

alert("数据库创建失败!");

} else {

alert("数据库创建成功!");

}

解释一下openDatabase方法打开一个已经存在的数据库,如果数据库不存在,它还可以创建数据库。几个参数意义分别是:

1,数据库名称。

2,版本号 目前为1.0,不管他,写死就OK。

3,对数据库的描述。

4,设置数据的大小。

5,回调函数(可省略)。

初次调用时创建数据库,以后就是建立连接了。

创建的数据库就存在本地,路径如下:

C:\Users\Administrator\AppData\Local\Google\Chrome\User Data\Default\databases\http_localhost_4987 。

创建的是一个sqllite数据库,可以用SQLiteSpy打开文件,可以看到里面的数据。SQLiteSpy是一个绿色软件,可以百度一下下载地址或SQLiteSpy官方下载:SQLiteSpy。

第二步:创建数据表

代码如下:

this.createTable=function() {

dataBase.transaction( function(tx) {

tx.executeSql(

"create table if not exists stu (id REAL UNIQUE, name TEXT)",

[],

function(tx,result){ alert('创建stu表成功'); },

function(tx, error){ alert('创建stu表失败:' + error.message);

});

});

}

解释一下,

executeSql函数有四个参数,其意义分别是:

1)表示查询的字符串,使用的SQL语言是SQLite 3.6.19。

2)插入到查询中问号所在处的字符串数据。

3)成功时执行的回调函数。返回两个参数:tx和执行的结果。

4)一个失败时执行的回调函数。返回两个参数:tx和失败的错误信息。

第三步:执行增删改查

1)添加数据:

代码如下:

this.insert = function () {

dataBase.transaction(function (tx) {

tx.executeSql(

"insert into stu (id, name) values(?, ?)",

[id, '徐明祥'],

function () { alert('添加数据成功'); },

function (tx, error) { alert('添加数据失败: ' + error.message);

} );

});

2)查询数据

代码如下:

this.query = function () {

dataBase.transaction(function (tx) {

tx.executeSql(

"select * from stu", [],

function (tx, result) { //执行成功的回调函数

//在这里对result 做你想要做的事情吧...........

},

function (tx, error) {

alert('查询失败: ' + error.message);

} );

});

}

解释一下

上面代码中执行成功的回调函数有一参数result。

result:查询出来的数据集。其数据类型为 SQLResultSet ,就如同C#中的DataTable。

SQLResultSet 的定义为:

代码如下:

interface SQLResultSet {

readonly attribute long insertId;

readonly attribute long rowsAffected;

readonly attribute SQLResultSetRowList rows;

};

其中最重要的属性—SQLResultSetRowList 类型的 rows 是数据集的“行” 。

rows 有两个属性:length、item 。

故,获取查询结果的某一行某一列的值 :result.rows[i].item[fieldname] 。

3)更新数据

代码如下:

this.update = function (id, name) {

dataBase.transaction(function (tx) {

tx.executeSql(

"update stu set name = ? where id= ?",

[name, id],

function (tx, result) {

},

function (tx, error) {

alert('更新失败: ' + error.message);

});

});

}

4)删除数据

代码如下:

this.del = function (id) {

dataBase.transaction(function (tx) {

tx.executeSql(

"delete from stu where id= ?",

[id],

function (tx, result) {

},

function (tx, error) {

alert('删除失败: ' + error.message);

});

});

}

5)删除数据表

代码如下:

this.dropTable = function () {

dataBase.transaction(function (tx) {

tx.executeSql('drop table stu');

});

}

html5 database storage查询怎么用

通过openDatabase方法创建一个访问数据库的对象

var db = openDatabase(databasename,version,description,size) ;

该方法有四个参数,作用分别为:

databasename:数据库名;

version:数据库版本号,可不填;

description:数据库描述;

size:给数据库分配的空间大小;

使用第一步创建的数据库访问对象(如db)执行transaction方法,用来执行事务处理,关于数据库的所有操作都需要在这里面进行,如执行查询

db.transaction(function(tx)){

//执行访问数据库的语句

tx.executeSql(sqlQuery,[value1,value2..],dataHandler,errorHandler)

});

通过executeSql方法执行查询,就是上面transaction中执行查询用到的方法。通过上面我们可以看出executeSql要在transaction中执行。下面详细介绍一下executeSql的参数和使用。

tx.executeSql(sqlQuery,[value1,value2..],dataHandler,errorHandler)

tx是transaction中传递过来的事务处理对象。

executeSql方法有四个参数,作用分别如下:

sqlQuery:需要具体执行的sql语句,可以是create、select、update、delete;

[value1,value2..]:sql语句中所有使用到的参数的数组,在executeSql方法中,将sql语句中所要使用的参数先用“?”代替,然后依次将这些参数组成数组放在第二个参数中;

dataHandler:执行成功是调用的回调函数,通过该函数可以获得查询结果集;

errorHandler:执行失败时调用的回调函数;

下面就做一个完整的实例,大家可以把代码复制下来存到一个html页面中,用chorme或火狐等支持html5的浏览器查看效果

!DOCTYPE HTML

html

head

meta charset="utf-8"/

titleHTML5本地存储之本地数据库篇/title

script type="text/javascript"

//打开数据库

var db = openDatabase('contactdb','','local database demo',204800);

//保存数据

function save(){

var user_name = document.getElementById("user_name").value;

var mobilephone = document.getElementById("mobilephone").value;

var company = document.getElementById("company").value;

//创建时间

var time = new Date().getTime();

db.transaction(function(tx){

tx.executeSql('insert into contact values(?,?,?,?)',[user_name,mobilephone,company,time],onSuccess,onError);

});

}

//sql语句执行成功后执行的回调函数

function onSuccess(tx,rs){

alert("操作成功");

loadAll();

}

//sql语句执行失败后执行的回调函数

function onError(tx,error){

alert("操作失败,失败信息:"+ error.message);

}

//将所有存储在sqlLite数据库中的联系人全部取出来

function loadAll(){

var list = document.getElementById("list");

db.transaction(function(tx){

//如果数据表不存在,则创建数据表

tx.executeSql('create table if not exists contact(name text,phone text,company text,createtime INTEGER)',[]);

//查询所有联系人记录

tx.executeSql('select * from contact',[],function(tx,rs){

if(rs.rows.length0){

var result = "table";

result += "trth序号/thth姓名/thth手机/thth公司/thth添加时间/thth操作/th/tr";

for(var i=0;irs.rows.length;i++){

var row = rs.rows.item(i);

//转换时间,并格式化输出

var time = new Date();

time.setTime(row.createtime);

var timeStr = time.format("yyyy-MM-dd hh:mm:ss");

//拼装一个表格的行节点

result += "trtd"+(i+1)+"/tdtd"+row.name+"/tdtd"+row.phone+"/tdtd"+row.company+"/tdtd"+timeStr+"/tdtdinput type='button' value='删除' onclick='del("+row.phone+")'//td/tr";

}

list.innerHTML = result;

}else{

list.innerHTML = "目前数据为空,赶紧开始加入联系人吧";

}

});

});

}

//删除联系人信息

function del(phone){

db.transaction(function(tx){

//注意这里需要显示的将传入的参数phone转变为字符串类型

tx.executeSql('delete from contact where phone=?',[String(phone)],onSuccess,onError);

});

}

//格式化时间的format函数

Date.prototype.format = function(format)

{

var o = {

"M+" : this.getMonth()+1, //month

"d+" : this.getDate(), //day

"h+" : this.getHours(), //hour

"m+" : this.getMinutes(), //minute

"s+" : this.getSeconds(), //second

"q+" : Math.floor((this.getMonth()+3)/3), //quarter

"S" : this.getMilliseconds() //millisecond

}

if(/(y+)/.test(format)) format=format.replace(RegExp.$1,

(this.getFullYear()+"").substr(4 - RegExp.$1.length));

for(var k in o)if(new RegExp("("+ k +")").test(format))

format = format.replace(RegExp.$1,

RegExp.$1.length==1 ? o[k] :

("00"+ o[k]).substr((""+ o[k]).length));

return format;

}

/script

style

.addDiv{

border: 2px dashed #ccc;

width:400px;

text-align:center;

}

th {

font: bold 11px "Trebuchet MS", Verdana, Arial, Helvetica, sans-serif;

color: #4f6b72;

border-right: 1px solid #C1DAD7;

border-bottom: 1px solid #C1DAD7;

border-top: 1px solid #C1DAD7;

letter-spacing: 2px;

text-transform: uppercase;

text-align: left;

padding: 6px 6px 6px 12px;

}

td {

border-right: 1px solid #C9DAD7;

border-bottom: 1px solid #C9DAD7;

background: #fff;

padding: 6px 6px 6px 12px;

color: #4f6b72;

}

/style

/head

body onload="loadAll()"

div class="addDiv"

label for="user_name"姓名:/label

input type="text" id="user_name" name="user_name" class="text"/

br/

label for="mobilephone"手机:/label

input type="text" id="mobilephone" name="mobilephone"/

br/

label for="mobilephone"公司:/label

input type="text" id="company" name="company"/

br/

input type="button" onclick="save()" value="新增记录"/

/div

br/

div id="list"

/div

/body

/html

HTML5如何和JAVA后台数据交互。如:查询功能,查询JAVA后台数据,展示在HTML5页面中。

这是一门课程了。java web,,或者叫jsp。jsp就是由html和java脚本,等语言构成的。

java程序嵌套在html里。相当于php。以网页的形式将java展现。这也就是所谓的动态。

以为java程序获取的时间会变动。或者数据库变动从而引起网页的变动。

具体实现,你可以在网上查找jsp教程。以下是一个jsp页面的例子:

%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%

注释(1):上面一句是jsp命令语句,标准形式%@ %表示,利用java脚本语言。引入java.util包里的所有文件。编码为utf-8

%

String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%

注释2:java脚本

之后是标准的html格式。可嵌入java代码

!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"

html

head

base href="%=basePath%"

titleMy JSP 'index.jsp' starting page/title

meta http-equiv="pragma" content="no-cache"

meta http-equiv="cache-control" content="no-cache"

meta http-equiv="expires" content="0"

meta http-equiv="keywords" content="keyword1,keyword2,keyword3"

meta http-equiv="description" content="This is my page"

!--

link rel="stylesheet" type="text/css" href="styles.css"

--

/head

body

This is my JSP page. br

可嵌入java脚本% %

/body

/html

HTML5查询功能代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于html5媒体查询、HTML5查询功能代码的信息别忘了在本站进行查找喔。

版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/19749.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载