首页 > 其他分享 >uniapp数据缓存和发起网络请求

uniapp数据缓存和发起网络请求

时间:2024-09-08 23:53:38浏览次数:3  
标签:username uniapp 存储 缓存 请求 age value uni

数据缓存


uni.onStorageSync同步的方式将数据存储到本地缓存


<template>
	<button @click="onStorageSync()">存储数据</button>
</template>

<script setup>
	const onStorageSync = () => {
		// 存储数据
		uni.setStorageSync('username', '张三');
		uni.setStorageSync('age', 25);
	};
</script>

uni.getStorageSync从本地存储中同步读取数据​​​​​​


<template>
	<button @click="onStorageSync()">存储数据</button>
	{{username}}
	{{age}}
	</template>

<script setup>
	import {
		ref
	} from 'vue';
	var username = ref('');
	var age = ref('');
	const onStorageSync = () => {
		// 存储数据
		uni.setStorageSync('username', '张三');
		uni.setStorageSync('age', 25);
		//获取数据并存储
		username.value = uni.getStorageSync('username');
		age.value = uni.getStorageSync('age');
	};
</script>

uni.removeStorageSync用于从本地存储中移除指定 key 的数据的方法。它可以帮助你在不需要某个数据项时将其从本地存储中删除。


<template>
	<!-- 存储数据按钮,点击后将调用onStorageSync()方法 -->
	<button @click="onStorageSync()">存储数据</button>
	<!-- 清除指定key存储数据的按钮,点击后将调用onRemoverStorageSunc()方法 -->
	<button @click="onRemoverStorageSunc()">清除指定key存储数据数据</button>
	<!-- 显示从存储中获取的用户名 -->
	{{ username }}
	<!-- 显示从存储中获取的年龄 -->
	{{ age }}
</template>

<script setup>
// 初始化用户名和年龄的响应式变量,初始值为空字符串
var username = ref('');
var age = ref('');
/**
 * 存储数据到本地存储,并更新响应式变量的值
 * 使用uni.setStorageSync方法存储数据,如果存储成功,通过uni.getStorageSync方法获取数据并更新变量值
 */
const onStorageSync = () => {
	// 存储数据
	uni.setStorageSync('username', '张三');
	uni.setStorageSync('age', 25);
	//获取数据并存储
	username.value = uni.getStorageSync('username');
	age.value = uni.getStorageSync('age');
};
/**
 * 移除本地存储中指定key的数据,并更新响应式变量的值
 * 使用uni.removeStorageSync方法移除存储的数据,然后尝试重新获取并更新变量值
 */
const onRemoverStorageSunc = () => {
	uni.removeStorageSync('username');
	uni.removeStorageSync('age');
	// 尝试重新获取数据并更新,此时数据已被移除,预期值为null或默认值
	username.value = uni.getStorageSync('username');
	age.value = uni.getStorageSync('age');
}
</script>

发起网络请求


uni.request 是 Uni-app 框架中用于发起 HTTP 网络请求的一个 API。它允许开发者向服务器发送请求以获取数据或发送数据。下面是一些基本的用法和作用:

        


作用

  • 数据获取:从远程服务器获取数据,例如获取 JSON 格式的数据。
  • 数据提交:向服务器发送数据,比如提交表单数据或上传文件。
  • 服务交互:与第三方服务进行通信,如身份验证、支付接口调用等。

基本用法

uni.request 接受一个对象作为参数,其中包含请求的相关配置项,比如 URL、请求方法、请求头、请求体等,并且可以指定回调函数来处理请求的结果。

参数说明
  • url (String):请求的地址。
  • data (Object/String):请求的参数,如果是 GET 请求,这些参数会被拼接在 URL 后面;如果是 POST 请求,则作为请求体发送。
  • method (String):请求的方法,默认为 GET,可选值有 GETPOSTPUTDELETEHEADOPTIONS 等。
  • timeout (Number):请求超时时间,单位毫秒,默认值为 60000。
  • complete (Function):接口调用结束的回调函数(请求结束时执行,无论成功或失败)。
  • success (Function):接口调用成功的回调函数。
  • fail (Function):接口调用失败的回调函数

<template>
</template>

<script setup>
// 使用uni.request发起一个GET请求到指定的URL
uni.request({
	url: 'https://jsonplaceholder.typicode.com/todos/1', // 请求的URL
	data: {
		key: 'value' // 请求携带的数据
	},
	method: 'GET', // 请求方法
	header: {
		'Content-Type': 'application/json', // 设置内容类型为JSON
		'Custom-Header': 'hello' // 自定义请求头
	},
	success: function(res) {
		console.log(res.data); // 处理返回的数据
	},
	fail: function(err) {
		console.error('请求失败:', err); // 在请求失败时输出错误信息
	}
})
</script>
<template>
  <div>
    <h1>请求结果</h1>
    <pre>{{ requestResult }}</pre>
  </div>
</template>

<script setup>
import { ref } from 'vue';

// 初始化状态
const requestResult = ref('');

// 使用uni.request发起GET请求
uni.request({
  url: 'https://jsonplaceholder.typicode.com/todos/1', // 请求的URL
  data: {
    key: 'value' // 请求的参数
  },
  method: 'GET', // 请求方法
  header: {
    'Content-Type': 'application/json', // 设置请求头的Content-Type
    'Custom-Header': 'hello' // 自定义请求头
  },
  success: function (res) {
    // 请求成功时的回调函数
    requestResult.value = JSON.stringify(res.data, null, 2); // 将数据转换为字符串并存储
  },
  fail: function (err) {
    // 请求失败时的回调函数
    console.error('请求失败:', err); // 输出错误信息到控制台
    requestResult.value = '请求失败'; // 设置状态为请求失败
  }
});
</script>



 

标签:username,uniapp,存储,缓存,请求,age,value,uni
From: https://blog.csdn.net/a1241436267/article/details/142034771

相关文章

  • Java中的请求幂等性处理:如何确保服务端的操作重复安全
    Java中的请求幂等性处理:如何确保服务端的操作重复安全大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!在服务端开发中,请求幂等性是确保系统稳定性和可靠性的关键因素之一。请求幂等性意味着一个操作可以重复执行多次,但其结果不会改变,这对于避免重复提......
  • 如何解决缓存(redis)和数据库(MySQL)数据不一致的问题?
    在使用缓存(如Redis)和数据库(如MySQL)时,数据不一致是常见的问题。通常,我们希望缓存能够提高系统的读性能,但同时也会面临缓存与数据库数据同步的问题。解决缓存与数据库数据不一致的问题有多种方法,常见的策略包括以下几种:1.缓存更新策略常用的缓存更新策略包括缓存穿透、缓存......
  • 抓包工具获取请求信息
    Charles下载安装下载官方下载地址:https://www.charlesproxy.com/latest-release/download.do下载后傻瓜式安装就好,这个官方的需要激活,可以选择绿色版或者学习版绿色版绿色中文版:https://soft.kxdw.com/pc/Charles.zip下载后解压,这个绿色中文版安装后可能报错,不管它,可以正常用解......
  • Uniapp基础学习(二)
    uni-app怎么用?和vue对比记忆一文教会你_uniappvue-CSDN博客一、项目结构解读uni-app项目的结构通常包括以下几个部分:pages:存放项目页面的目录,每个页面通常由.vue文件、.js文件、.json文件等组成。components:存放可复用的Vue组件的目录。static:存放静态资源(如图片、视频等)的目录。u......
  • 解决SpringBoot 接口恶意刷新和暴力请求!!
    在实际项目使用中,必须要考虑服务的安全性,当服务部署到互联网以后,就要考虑服务被恶意请求和暴力攻击的情况,下面的教程,通过intercept和redis针对url+ip在一定时间内访问的次数来将ip禁用,可以根据自己的需求进行相应的修改,来打打自己的目的;首先工程为springboot框架搭建,不再详细......
  • 配置PHP的Session存储到Mysql / Redis / memcache 以及使用opcache以及apc缓存清除工
    一、配置PHP的Session存储到Mysql,Redis以及memcache等        PHP的会话默认是以文件的形式存在的,可以通过简单的配置到将Session存储到NoSQL中,即提高了访问速度,又能很好地实现会话共享!1.默认配置:session.save_handler=filessession.save_path=/tmp/2.配......
  • 基于SpringBoot+Vue+uniapp的网上药品售卖系统的详细设计和实现(源码+lw+部署文档+讲
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......
  • 基于SpringBoot+Vue+uniapp的医院住院综合服务管理系统设计与开发+vue的详细设计和实
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......
  • 基于ssm+vue+uniapp的“最多跑一次”小程序
    开发语言:Java框架:ssm+uniappJDK版本:JDK1.8服务器:tomcat7数据库:mysql5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:Maven3.3.9系统展示后台登录界面管理员功能界面用户管理民警管理服务信息管理类型管理预约信息管理报案信息管理......
  • SpringBoot兼容SpringMVC带有.do后缀的请求
    背景MVC框架请求的都是.do后缀,但controller控制层拦截的是没有后缀的链接。如controller请求/111/222,当请求/111/222.do时,可以正常进入。当我们将存量一些旧工程(SpringMVC框架)升级到Springboot后,发现无法进入,此处我们针对这块进行最丝滑的适配。版本信息Springboot:2.7.17方......