主頁 > 前端設計 > 聽說MongoDB你很豪橫?-------------MongoDB資料庫基礎詳解

聽說MongoDB你很豪橫?-------------MongoDB資料庫基礎詳解

2020-09-14 08:40:41 前端設計

文章目錄

  • 一、 MongoDB相關概念
    • 1、業務應用場景
    • 2、MongoDB可應對“三高"需求,
    • 3、什么時候選擇MongoDB ?
  • 二、MongoDB簡介
    • 1、體系結構
    • 2、資料模型
  • 三、MongoDB的特點
  • 四、安裝MongoDB
    • 1、配置本地yum源
    • 2、yum安裝
    • 3、修改組態檔
    • 4、啟動mongodb
    • 5、進入MongoDB資料庫
  • 五、資料庫簡單的操作命令
    • 1、選擇和創建資料庫
    • 2、資料庫的洗掉
    • 3、集合的隱式創建與洗掉
    • 4、插入資料
    • 5、更改資料
  • 六、匯入匯出
    • 1、匯出school庫的info表:
    • 2、查看匯出檔案:
    • 3、匯入:(匯入一個新表info2,如果表不存在,會新建這個表)
    • 4、進入資料庫驗證
    • 5、基于條件的匯出:(匯出info表里id=10的記錄)
  • 七、備份恢復
  • 八、克隆
    • 1、克隆資料庫
    • 2、克隆集合(表)

一、 MongoDB相關概念

1、業務應用場景

傳統的關系型資料庫(如MySQL) ,在資料操作的"三高需求以及應對Web2.0的網站需求面前,顯得力不從心,
解釋:“三高”需求:
●High performance -對資料庫并發讀寫的需求,
●Huge Storage -對海量資料的高效率存盤和訪問的需求,
●High Scalability & High Availability-對資料庫的高可擴展性和高可用性的需求,

2、MongoDB可應對“三高"需求,

具體的應用場景如:

  • 1)社交場景,使用MongoDB存盤存盤用戶資訊,以及用戶發表的朋友圈資訊,通過地理位置索實作附近的
    人地點等功能,
  • 2)游戲場景,使用MongoDB存盤游戲用戶資訊,用戶的裝備、積分等直接以內嵌檔案的形式存盤,方便查詢、
    高敲率存盤和訪問,
  • 3)物流場景,使用MongoDB存盤訂單資訊,訂單狀態在運送程序中會不斷更新,以MongoDB內嵌陣列的形式
    來存盤,- -次查詢就能將訂單所有的變更讀取出來,
  • 4)物聯網場景,使用MongoDB存盤所有接入的智能設備資訊,以及設備匯報的日志資訊,并對這些資訊進行多
    維度的分析,
  • 5)視頻直播,使用MongoDB存盤用戶資訊、點贊互動資訊等,

這些應用場景中,資料操作方面的共同特點是:

  • (1)資料量大
  • (2)寫入操作頻繁(讀寫都很頻繁)
  • (3)價值較低的資料,對事務性要求不高
    對于這樣的資料,我們更適合使用MongoDB來實作資料的存盤,

3、什么時候選擇MongoDB ?

在架構選型上,除了上述的三個特點外,如果你還猶豫是否要選擇它?可以考慮以下的一些問題:
應用不需要事務及復雜join支持
新應用,需求會變,資料模型無法確定,想快速迭代開發
應用需要2000-3000以上的讀寫QPS (更高也可以)
應用需要TB甚至PB級別資料存盤
應用發展迅速,需要能快速水平擴展
應用要求存盤的資料不失
應用需要99.999%高可用
應用需要大量的地理位置查詢、文本查詢
如果上述有1個符合,可以考慮MongoDB, 2個及以上的符合,選擇MongoDB絕不會后悔,

如果用MySQL呢?
相對MySQL,可以以更低的成本解決問題(包括學習、開發、運維等成本)

二、MongoDB簡介

MongoDB是一個開源、 高性能、無模式的檔案型資料庫,當初的設計就是用于簡化開發和方便擴展,是NoSQL數
據庫產品中的一種,是最像關系型資料庫(MySQL) 的非關系型資料庫,
它支持的資料結構非常松散,是一種類似于JSON的格式叫BSON,所以它既可以存盤比較復雜的資料型別,又相
當的靈活,
MongoDB中的記錄是一個檔案, 它是一個由欄位和值對(field:value) 組成的資料結構,MongoDB檔案類似于
JSON物件,即一個檔案認為就是一個物件,欄位的資料型別是字符型,它的值除了使用基本的一些型別外,還可
以包括其他檔案、普通陣列和檔案陣列,

1、體系結構

在這里插入圖片描述
在這里插入圖片描述

2、資料模型

MongoDB的最小存盤單位就是檔案(document)物件,檔案(document)物件對應于關系型資料庫的行,資料在
MongoDB中以BSON (Binary-JSON) 檔案的格式存盤在磁盤上,
BSON (Binary Serialized Document Format)是-種類json的一 種二進制形式的存盤格式,簡稱Binary JSON,
BSON和JSON-樣,支持內嵌的檔案物件和陣列物件,但是BSON有JSON沒有的一-些資料型別,如Date和
BinData型別,
在這里插入圖片描述

三、MongoDB的特點

MongoDB主要有如下特點:

  • (1)高性能:
    MongoDB提供高性能的資料持久性,特別是,
    對嵌入式資料模型的支持減少了資料庫系統上的I/0活動,
    弓支持更快的查詢,并且可以包含來自嵌入式檔案和陣列的鍵,(文本索引解決搜索的需求、 TTL索引解決歷史資料自動過期的需求、地理位置索弓可用于構建各種020應用)
    mmapv1、wiredtiger、 mongorocks (rocksdb) 、in-memory 等多引擎支持滿足各種場景需求,
    Gridfs解決檔案存盤的需求,
  • (2)高可用性: .
    MongoDB的復制工具稱為副本集(replica set),它可提供自動故障轉移和資料冗余,
  • (3)高擴展性:
    MongoDB提供了水平可擴展性作為其核心功能的一部分,
    分片將資料分布在一組集群的機器上,(海量資料存盤, 服務能力水平擴展)
    從3.4開始,MongoDB支持基于片 鍵創建資料區域,在一個平衡的集群中, MongoDB將-個區域所覆寫的讀寫只
    定向到該區域內的那些片,
  • (4)豐富的查詢支持:
    MongoDB支持豐富的查詢語言,支持讀和寫操作(CRUD),比如資料聚合、文本搜索和地理空間查詢等,
  • (5) 其他特點:如無模式(動態模式)、 靈活的檔案模型、

四、安裝MongoDB

1、配置本地yum源

[root@mongodb yum.repos.d]# vim /etc/yum.repos.d/mongodb-org-4.0.repo

[mongodb-org-4.0]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.0/x86_64/
gpgcheck=0
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.0.asc

2、yum安裝

yum list
[root@mongodb yum.repos.d]# yum -y install mongodb-org

[root@mongodb yum.repos.d]# whereis mongod   <-----查看mongodb的組態檔位置
mongod: /usr/bin/mongod /etc/mongod.conf /usr/share/man/man1/mongod.1

3、修改組態檔

systemlog:
MongoDB發送所有日志輸出的目標指定為檔案
# #The path of the 1og file to which mongod or mongos should send a11 di agnostic logging
i nformation
destination: file 
#mongod或mongos應向其發送所有診斷日志記錄資訊的日志檔案的路徑
path: "/mongodb/sing1e/1og/mongod. log"
#當mongos或mongod實體重新啟動時,mongos或mongod會將新條目附加到現有日志檔案的末尾,
logAppend: true
stor age:
#mongod實體存盤其資料的目錄,stor age . dbPath設定僅適用于mongod,
##The directory where the mongod instance stores its data.Default value is " /data/db".
dbPath: " /mongodb/sing1e/data/db"
journa1:
#啟用或禁用持久性日志以確保資料檔案保持有效和可恢復,當資料庫發生宕機后,將資料庫的狀態恢復到之前
enabled: true
proces sManagement :
#啟用在后臺運行mongos或mongod行程的守護行程模式,
fork: true
net:
#服務實體系結的IP,默認是localhost
bindIp: localhost 0.0.0.0  '監聽所有埠'
#bindIp
#系結的埠,默認是27017
port: 27017

4、啟動mongodb

[root@mongodb yum.repos.d]# systemctl start mongod

[root@mongodb yum.repos.d]# netstat -anpt | grep 27017
tcp        0      0 0.0.0.0:27017           0.0.0.0:*               LISTEN      20265/mongod 

5、進入MongoDB資料庫

[root@mongodb ~]# mongo
MongoDB shell version v4.0.20
connecting to: mongodb://127.0.0.1:27017/?gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("760a7212-96f3-4d9b-b426-94b331ad2b10") }
MongoDB server version: 4.0.20
Welcome to the MongoDB shell.
For interactive help, type "help".
For more comprehensive documentation, see
	http://docs.mongodb.org/
Questions? Try the support group
	http://groups.google.com/group/mongodb-user
Server has startup warnings: 
……省略部分內容

> show dbs    <-----查看資料庫
admin   0.000GB
config  0.000GB
local   0.000GB
> exit   <-----退出,或者按ctrl+c退出
bye
[root@mongodb ~]# 

五、資料庫簡單的操作命令

資料庫名可以是滿足以下條件的任意UTF-8字串,

  • 不能是空字串("), .
  • 不得含有’ (空格)、、$、1、\和h0 (空字符),
  • 應全部小寫,
  • 最多64位元組,

MongoDBmore的三個資料庫

  • admin:從權限的角度來看,這是"root’資料庫,要是將一個用戶添加到這個資料庫, 這個用戶自動繼承所
    有資料庫的權限,一些特定的服務器端命令也只能從這個資料庫運行,比如列出所有的資料庫或者關閉服務
    器,
  • local:這個資料永遠不會被復制,可以用來存盤限于本地單臺服務器的任意集合
  • config: 當Mongo用于分片設定時,config資料庫在內部使用, 用于保存分片的相關資訊,

1、選擇和創建資料庫

選擇和創建資料庫的語法格式: .
use資料庫名稱
如果資料庫不存在則自動創建,例如,以下陳述句創建spitdb資料庫:
如果有的話直接就進入到這個資料庫中

use articledb

查看有權限查看的所有的資料庫命令

show dbs

show databases

注意:在MongoDB中,集合只有在內容插入后才會創建!就是說,創建集合(資料表)后要再插入一個檔案(錄),集合才會真正創建,
#查看當前正在使用的資料庫命令
MongoDB中默認的資料庫為test,如果你沒有選擇資料庫,集合將存放在test資料庫中,

2、資料庫的洗掉

MongoDB洗掉資料庫的語法格式如下:

> db.dropDatabase();
{ "ok" : 1 }

提示:主要用來洗掉已經持久化的資料庫,而記憶體中還是有這個庫的
在這里插入圖片描述

3、集合的隱式創建與洗掉

基本語法格式: .

db.createCollection(“shang”)
{ “ok” : 1 }

引數說明:

查看當前庫中的表: show tables命令
show collections

show tables

當向一個集合中插入一個檔案的時候,如果集合不存在,則會自動創建集合,

提示:通常我們使用隱式創建檔案即可,

集合洗掉語法格式如下:
db. collection. drop()

db .集合.drop()
回傳值
如果成功洗掉選定集合,則drop()方法回傳true,否則回傳false,

db.shang.drop()
true

4、插入資料

要向info的集合(表)中插入一條測驗資料:

db.createCollection(‘info’) //新建info表,如果不手動創建集合;向不存在的集合中第一次加入資料的時候,集合會被自動創建出來
{ “ok” : 1 }

提示:

  1. info集合如果不存在,則會隱式創建
  2. mongo中的數字,默認情況下是double型別,如果要存整型,必須使用函式Numberlnt(整型數字),否則取出來就有問題了,
    3)插入當前日期使用new Date()
    4)插入的資料沒有指定. _id,會自動生成主鍵值
    5)如果某欄位沒值,可以賦值為null,或不寫該欄位,
    執行后,如下,說明插入一個資料成功了,
    Wr iteResult({ “nInserted” : 1 })

利用for回圈批量添加用戶

> for(var i=2;i<=100;i++)db.info.insert({"id":1,"name":"jack"+i})
> { "_id" : ObjectId("5f5b1f18a53aea026deda1d6"), "id" : 1, "name" : "jack2" }
{ "_id" : ObjectId("5f5b1f18a53aea026deda1d7"), "id" : 1, "name" : "jack3" }
{ "_id" : ObjectId("5f5b1f18a53aea026deda1d8"), "id" : 1, "name" : "jack4" }
{ "_id" : ObjectId("5f5b1f18a53aea026deda1d9"), "id" : 1, "name" : "jack5" }
{ "_id" : ObjectId("5f5b1f18a53aea026deda1da"), "id" : 1, "name" : "jack6" }
{ "_id" : ObjectId("5f5b1f18a53aea026deda1db"), "id" : 1, "name" : "jack7" }

查詢name欄位中jack10的資訊

> db.info.findOne({name:"jack10"})
{
	"_id" : ObjectId("5f5b3018c34c98ad91e8673c"),
	"id" : 1,
	"name" : "jack10"
}
> 

查詢欄位的type型別

> a=db.info.findOne({name:"jack10"})
{
	"_id" : ObjectId("5f5b3018c34c98ad91e8673c"),
	"id" : 1,
	"name" : "jack10"
}
> typeof(a.id)
number
> 
> typeof(a.name)
string

這里你會發現每條檔案會有一個叫_id的欄位,這個相當于我們原來關系資料庫中表的主鍵,當你在插入檔案記錄時沒有指定該欄位,MongoDB會自動創建,其型別是ObjectID型別,
如果我們在插入檔案記錄時指定該欄位也可以,其型別可以是ObjectID型別,也可以是MongoDB支持的任意類
型,

5、更改資料

修改id=1的記錄的name為tom
> db.info.update({"id":1},{$set:{"name":"tom"}})  
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

>db.info.find()
{ "_id" : ObjectId("5f56eafbbb50f14e91ed31e0"), "id" : 1, "name" : "tom", "score" : 90, "hobby" : [ "game", "music", "sport" ] }

六、匯入匯出

-d:指定資料庫
-c:指定表
-o:指定匯出檔案
–file:指定從哪個檔案匯入

1、匯出school庫的info表:

[root@mongodb ~]# mongoexport -d school -c info -o /opt/school.json
2020-09-08T11:56:53.466+0800	connected to: localhost
2020-09-08T11:56:53.467+0800	exported 1 record

2、查看匯出檔案:

[root@mongodb ~]# vim /opt/school.json

{"_id":{"$oid":"5f56eafbbb50f14e91ed31e0"},"id":1.0,"name":"tom","score":90.0,"hobby":["game","music","sport"]}

3、匯入:(匯入一個新表info2,如果表不存在,會新建這個表)

[root@mongodb ~]# mongoimport -d school -c info2 --file /opt/school.json
2020-09-08T11:58:46.720+0800	connected to: localhost
2020-09-08T11:58:46.732+0800	imported 1 document

4、進入資料庫驗證

[root@mongodb ~]# mongo

> use school
switched to db school
> show tables
info
info2
> db.info2.find()
{ "_id" : ObjectId("5f56eafbbb50f14e91ed31e0"), "id" : 1, "name" : "tom", "score" : 90, "hobby" : [ "game", "music", "sport" ] }

5、基于條件的匯出:(匯出info表里id=10的記錄)

[root@mongodb ~]# mongoexport -d school -c info -q '{"id":{"$eq":10}}' -o /opt/top10.json
2020-09-08T12:12:26.122+0800	connected to: localhost
2020-09-08T12:12:26.123+0800	exported 1 record

查詢條件運算子:
(=) 等于 - $eq
(>) 大于 - $gt
(<) 小于 - $lt
(>=) 大于等于 - $gte
(<= ) 小于等于 - $lte

查看匯出檔案:

[root@mongodb ~]# vim /opt/top10.json 

{"_id":{"$oid":"5f570266a1451cb5e42060cc"},"id":10.0,"name":"jack10"}

七、備份恢復

備份命令mongodump
恢復命令mongorestore

需要在shell命令列操作

[root@mongodb ~]# mkdir /bak   //新建備份目錄
[root@mongodb ~]# mongodump -d school -o /bak   //備份到/bak目錄
2020-09-08T12:15:12.357+0800	writing school.info to 
2020-09-08T12:15:12.357+0800	writing school.info2 to 
2020-09-08T12:15:12.359+0800	done dumping school.info2 (1 document)
2020-09-08T12:15:12.359+0800	done dumping school.info (100 documents)
[root@mongodb ~]# ls /bak/
school
[root@mongodb ~]# cd /bak/school
[root@mongodb school]# ls
info2.bson  info2.metadata.json  info.bson  info.metadata.json
從備份目錄恢復資料庫,資料庫不存在的話會自動創建
[root@mongodb school]# mongorestore -d school2 --dir=/bak/school
2020-09-08T12:17:39.469+0800	the --db and --collection args should only be used when restoring from a BSON file. Other uses are deprecated and will not exist in the future; use --nsInclude instead
2020-09-08T12:17:39.470+0800	building a list of collections to restore from /bak/school dir
2020-09-08T12:17:39.470+0800	reading metadata for school2.info2 from /bak/school/info2.metadata.json
2020-09-08T12:17:39.471+0800	reading metadata for school2.info from /bak/school/info.metadata.json
2020-09-08T12:17:39.477+0800	restoring school2.info2 from /bak/school/info2.bson
2020-09-08T12:17:39.483+0800	restoring school2.info from /bak/school/info.bson
2020-09-08T12:17:39.484+0800	no indexes to restore
2020-09-08T12:17:39.484+0800	finished restoring school2.info2 (1 document)
2020-09-08T12:17:39.487+0800	no indexes to restore
2020-09-08T12:17:39.487+0800	finished restoring school2.info (100 documents)
2020-09-08T12:17:39.487+0800	done
[root@mongodb school]# 
//還原指定資料庫,這個資料庫可以是一個新的,不存在的,它會自己創建

進入資料庫驗證

> show dbs;
admin    0.000GB
config   0.000GB
local    0.000GB
school   0.000GB
school2  0.000GB
> use school2
switched to db school2
> show tables
info
info2

八、克隆

1、克隆資料庫

db.copyDatabase在4.0以后已經被棄用,但是依然可以成功

> db.copyDatabase("school","share")   //復制資料庫,新庫叫share
WARNING: db.copyDatabase is deprecated. See http://dochub.mongodb.org/core/copydb-clone-deprecation
{
	"note" : "Support for the copydb command has been deprecated. See http://dochub.mongodb.org/core/copydb-clone-deprecation",
	"ok" : 1
}
> show dbs;
admin    0.000GB
config   0.000GB
local    0.000GB
school   0.000GB
school2  0.000GB
share    0.000GB

2、克隆集合(表)

要先創建多實體再為多實體創建資料目錄

> use school
switched to db school
> show tables
info
> db.info.drop()
true
> db.runCommand({"cloneCollection":"school.info","from":"192.168.110.133:27017"})
{ "ok" : 1 }
> show tables
info

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/32917.html

標籤:其他

上一篇:Js中通過XMLHttpRequest呼叫讀取本機json檔案的疑問

下一篇:資料庫綜合練習

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more