index.html 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <!DOCTYPE html>
  2. <html lang="zh-cn">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>sqlite数据库测试</title>
  6. <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
  7. <script src="https://cdn.bootcss.com/sql.js/0.5.0/js/sql-optimized.js"></script>
  8. </head>
  9. <body>
  10. <p>sqlite数据库测试,使用js操作sqlite数据库</p>
  11. <p>这里使用axios读取test.db文件,进行初始化数据库连接,</p>
  12. <p>查询速度不快,除非不想写后台要直接操作数据库,不然没什么用。</p>
  13. <p>具体效果可查看代码和控制台打印的数据。</p>
  14. <script>
  15. // 读取数据库数据
  16. axios.get("chinese.db", {responseType: 'arraybuffer'})
  17. .then(function (response) {
  18. let db = new window.SQL.Database(new Uint8Array(response.data));
  19. // 执行查询
  20. let s = new Date().getTime();
  21. let r = db.exec("SELECT * FROM chinese WHERE id between 13000 and 13010;");
  22. let e = new Date().getTime();
  23. document.write("查询数据耗时:" + (e - s) + "ms");
  24. // 解析数据
  25. let obj = dbToObj(r);
  26. console.info(obj);
  27. document.write('<table border="1">');
  28. obj.forEach(
  29. function (value) {
  30. document.write('<tr>');
  31. document.write('<td>'+value.id+'</td>');
  32. document.write('<td>'+value.font+'</td>');
  33. document.write('<td>'+value.type+'</td>');
  34. document.write('<td>'+value.time+'</td>');
  35. document.write('<td>'+value.author+'</td>');
  36. var path='../res/';
  37. path+=value.font+"_"+value.time+"_"+value.author+'_'+value.type;
  38. path+='.png';
  39. document.write('<td><img src='+path+"></td>");
  40. document.write('</tr>');
  41. }
  42. );
  43. document.write('</table>');
  44. })
  45. .catch(function (error) {
  46. console.info(error);
  47. });
  48. // 方法传入两个数组,第一个数组为key,第二个数组对应位置为value,此方法在Python中为zip()函数。
  49. const ArraytoObj = (keys = [], values = []) => {
  50. if (keys.length === 0 || values.length === 0) return {};
  51. const len = keys.length > values.length ? values.length : keys.length;
  52. const obj = {};
  53. for (let i = 0; i < len; ++i) {
  54. obj[keys[i]] = values[i]
  55. }
  56. return obj;
  57. };
  58. // 转驼峰表示:func.camel('USER_ROLE',true) => UserRole
  59. // 转驼峰表示:func.camel('USER_ROLE',false) => userRole
  60. const camel = (str, firstUpper = false) => {
  61. let ret = str.toLowerCase();
  62. ret = ret.replace(/_([\w+])/g, function (all, letter) {
  63. return letter.toUpperCase();
  64. });
  65. if (firstUpper) {
  66. ret = ret.replace(/\b(\w)(\w*)/g, function ($0, $1, $2) {
  67. return $1.toUpperCase() + $2;
  68. });
  69. }
  70. return ret;
  71. };
  72. // 把数组里面的所有转化为驼峰命名
  73. const camelArr = (arrs = []) => {
  74. let _arrs = [];
  75. arrs.map(function (item) {
  76. _arrs.push(camel(item));
  77. });
  78. return _arrs;
  79. };
  80. // 读取数据库
  81. // 1.把columns转化为驼峰;
  82. // 2.把columns和values进行组合;
  83. const dbToObj = (_data = {}) => {
  84. let _res = [];
  85. _data.map(function (item) {
  86. let _columns = camelArr(item.columns);
  87. item.values.map(function (values) {
  88. _res.push(ArraytoObj(_columns, values));
  89. });
  90. });
  91. return _res;
  92. };
  93. </script>
  94. </body>
  95. </html>