• 技术文章 >web前端 >前端问答

    本地数据库是html5新特性吗

    青灯夜游青灯夜游2022-01-23 16:41:18原创64

    本地数据库是html5新特性。Html5提供了一个浏览器端的数据库支持,允许开发者直接通JS的API在浏览器端创建一个本地的数据库,而且支持标准的SQL的CRUD操作,让离线的Web应用更加方便的存储结构化的数据。

    本教程操作环境:windows7系统、HTML5版、Dell G3电脑。

    虽然Html5已经提供了功能强大的localStorage和sessionStorage,但是他们两个都只能提供存储简单数据结构的数据,对于复杂的Web应用的数据却无能为力。逆天的是Html5提供了一个浏览器端的数据库支持,允许我们直接通JS的API在浏览器端创建一个本地的数据库,而且支持标准的SQL的CRUD操作,让离线的Web应用更加方便的存储结构化的数据。接下里介绍一下本地数据的相关API和用法。

    操作本地数据库的最基本的步骤是:

    接下来分别介绍一下相关的方法的参数和用法。

    (1)openDatabase方法:

    //Demo:获取或者创建一个数据库,如果数据库不存在那么创建之
    var dataBase = openDatabase("student", "1.0", "学生表", 1024 * 1024, function () { });

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

    (2)db.transaction方法可以设置一个回调函数,此函数可以接受一个参数就是我们开启的事务的对象。然后通过此对象可以进行执行Sql脚本,跟下面的步骤可以结合起来。

    (3)通过executeSql方法执行查询。

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

    参数说明:

    下面是一个综合的例子,可以看一下:

    <head>
     <script src="Scripts/jquery-1.5.1.js" type="text/javascript"></script>
        <script type="text/javascript">
            function initDatabase() {
                var db = getCurrentDb();//初始化数据库
                if(!db) {alert("您的浏览器不支持HTML5本地数据库");return;}
                db.transaction(function (trans) {//启动一个事务,并设置回调函数
                    //执行创建表的Sql脚本
                    trans.executeSql("create table if not exists Demo(uName text null,title text null,words text null)", [], function (trans, result) {
                    }, function (trans, message) {//消息的回调函数alert(message);});
                }, function (trans, result) {
                }, function (trans, message) {
                });
            }
            $(function () {//页面加载完成后绑定页面按钮的点击事件
                initDatabase();
                $("#btnSave").click(function () {
                    var txtName = $("#txtName").val();
                    var txtTitle = $("#txtTitle").val();
                    var txtWords = $("#txtWords").val();
                    var db = getCurrentDb();
                    //执行sql脚本,插入数据
                    db.transaction(function (trans) {
                        trans.executeSql("insert into Demo(uName,title,words) values(?,?,?) ", [txtName, txtTitle, txtWords], function (ts, data) {
                        }, function (ts, message) {
                            alert(message);
                        });
                    });
                    showAllTheData();
                });
            });
            function getCurrentDb() {
                //打开数据库,或者直接连接数据库参数:数据库名称,版本,概述,大小
                //如果数据库不存在那么创建之
                var db = openDatabase("myDb", "1.0", "it's to save demo data!", 1024 * 1024); ;
                return db;
            }
            //显示所有数据库中的数据到页面上去
            function showAllTheData() {
                $("#tblData").empty();
                var db = getCurrentDb();
                db.transaction(function (trans) {
                    trans.executeSql("select * from Demo ", [], function (ts, data) {
                        if (data) {
                            for (var i = 0; i < data.rows.length; i++) {
                                appendDataToTable(data.rows.item(i));//获取某行数据的json对象
                            }
                        }
                    }, function (ts, message) {alert(message);var tst = message;});
                });
            }
            function appendDataToTable(data) {//将数据展示到表格里面
                //uName,title,words
                var txtName = data.uName;
                var txtTitle = data.title;
                var words = data.words;
                var strHtml = "";
                strHtml += "<tr>";
                strHtml += "<td>"+txtName+"</td>";
                strHtml += "<td>" + txtTitle + "</td>";
                strHtml += "<td>" + words + "</td>";
                strHtml += "</tr>";
                $("#tblData").append(strHtml);
            }
        </script>
    </head>
        <body>
            <table>
                <tr>
                    <td>用户名:</td>
                    <td><input type="text" name="txtName" id="txtName" required/></td>
                </tr>
                   <tr>
                    <td>标题:</td>
                    <td><input type="text" name="txtTitle" id="txtTitle" required/></td>
                </tr>
                <tr>
                    <td>留言:</td>
                    <td><input type="text" name="txtWords" id="txtWords" required/></td>
                </tr>
            </table>
            <input type="button" value="保存" id="btnSave"/>
            <hr/>
            <input type="button" value="展示所哟数据" onclick="showAllTheData();"/>
            <table id="tblData">
            </table>
        </body>
    </html>

    执行的效果如图:


    相关推荐:《html视频教程

    以上就是本地数据库是html5新特性吗的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:html5中表单验证的方式有哪几种 下一篇:html5是否区分大小写

    相关文章推荐

    • 语义化是不是html5新特性• html5中hr标签能用css吗• html5开发与混合开发的区别是什么• html5怎样设置嵌套内p标签不换行• html5支持哪几种音频格式• html5哪些标签可以做seo优化

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网