uni-app を使用した uniCloud クラウド データベースの使用開始: 簡単な追加、削除、変更、クエリの実装

公式クラウドデータベースドキュメント

前段階: uni-app を使用して新しい uniCloud プロジェクトを作成します
ここに画像の説明を挿入します
[外部リンクの画像転送に失敗しました。ソース サイトには盗難防止用の公式クラウド データベース ドキュメントがある可能性があります]! リンク メカニズムでは、() https://uniapp を推奨します。 dcloud.net.cn/uniCloud /hellodb.html)]

新しいテーブルを作成する

ここに画像の説明を挿入します
ここでは、createTime、remark、money といういくつかのテスト フィールドを追加しました。

// 文档教程: https://uniapp.dcloud.net.cn/uniCloud/schema
{
    
    
	"bsonType": "object",
	"required": [],
	"permission": {
    
    
		"read": true,
		"create": true,
		"update": true,
		"delete": true
	},
	"properties": {
    
    
		"_id": {
    
    
			"description": "ID,系统自动生成"
		},
		"createTime":{
    
    
			"bosnType":"string"
		},
		"remark":{
    
    
			"bosnType":"string"
		},
		"money":{
    
    
			"bosnType":"number"
		}
	}
}

効果

ここに画像の説明を挿入します

完全なコード

<template>
	<view>
		<input v-model="form.remark" placeholder="备注" type="text">
		<input v-model="form.money" type="number" placeholder="金额">
		<button @click="clickAdd">新增</button>

		<view class="list" v-for="item in list" :key="item._id">
			{
   
   {item.remark}}
			<button style="width:2em;" @click="clickDelete(item._id)">删除</button>
		</view>
	</view>
</template>

<script setup>
	import {
      
      
		reactive,
		ref
	} from 'vue';
	import {
      
      
		onShow
	} from "@dcloudio/uni-app"
	const form = reactive({
      
      
		remark: '',
		money: 0
	})
	const list = ref([]);
	const db = uniCloud.database()

	// 新增
	function clickAdd() {
      
      
		db.collection('list').add({
      
      
			createTime: new Date(),
			remark: form.remark,
			money: form.money
		}).then((res) => {
      
      
			getList()
			// uni.navigateBack()
		}).catch((err) => {
      
      
			uni.showModal({
      
      
				content: err.message || '请求服务失败',
				showCancel: false
			})
		})
	}

	onShow(() => {
      
      
		getList();
	})

	// 列表查询
	async function getList() {
      
      
		let {
      
      
			result
		} = await db.collection("list").get();
		console.log(result)
		list.value = result.data;
	}

	async function clickDelete(_id) {
      
      
		await db.collection("list").doc(_id).remove();
		getList()
	}
</script>

<style scoped>
	.list {
      
      
		color: #000;
		background-color: pink;
		margin-bottom: 36rpx;
	}
</style>

おすすめ

転載: blog.csdn.net/weixin_35958891/article/details/132078249