uniapp第一天

<template>
	<view class="layout">
		<view class="box1" hover-class="down" hover-start-time="1000"
		hover-stay-time="2000">
		<!-- 子元素 -->
			<view class="inner" hover-class="down2"
			hover-stop-propagation="true">
			<!-- 阻止事件冒泡 -->
				inner
			</view>
		</view>
		<view class="box2">
			box2
		</view>
		<view>-------</view>
		<text selectable="true" space="nbsp">112 如   果21</text>
	</view>
</template>

<script setup>
	
</script>

<style lang="scss">
	.layout{
		border:1px solid red;
		.box1{
			border:1px solid green;
		}
		.box2{
			border:1px solid blue;
		}
	}
	.down{
		background-color: pink;
		width:300px;
		height: 300px;
	}
	.inner{
		width: 150px;
		height: 150px;
		background-color: green;
	}
		
	.down2{
		background-color: white;
	}
</style>

view等价于div,属性

属性名类型默认值说明
hover-classStringnone指定按下去的样式类。当 hover-class="none" 时,没有点击态效果
hover-stop-propagationBooleanfalse指定是否阻止本节点的祖先节点出现点击态,App、H5、支付宝小程序、百度小程序不支持(支付宝小程序、百度小程序文档中都有此属性,实测未支持)
hover-start-timeNumber50按住后多久出现点击态,单位毫秒
hover-stay-timeNumber400手指松开后点击态保留时间,单位毫秒

hover-stop-propagation阻止事件冒泡

text相当于span,text里面的文字才能被选中,复制。

scroll-view属性:scroll-y竖向滚动,

scroll-x横向滚动,条件:在父元素中添加:white-space:nowrap(禁止换行)

在子元素中添加:display: inline-block;行级块元素

swiper轮播图,内部是swiper-item,swiper加入属性vertical,变成企业邀请函

里面插入image标签:有很多属性,查看官方文档

navigator跳转

button按钮

input输入

属性很多:其中

confirm-type 有效值

弹出软键盘的右下角按钮的文字。

说明平台差异说明
send右下角按钮为“发送”微信、支付宝、百度小程序、快手小程序、京东小程序、app-nvue、app-vue和h5(2.9.9+,且要求设备webview内核Chrome81+、Safari13.7+)
search右下角按钮为“搜索”
next右下角按钮为“下一个”微信、支付宝、百度小程序、快手小程序、京东小程序、app-nvue、app-vue和h5(2.9.9+,且要求设备webview内核Chrome81+、Safari13.7+)
go右下角按钮为“前往”
done右下角按钮为“完成”微信、支付宝、百度小程序、快手小程序、京东小程序、app-nvue、app-vue和h5(2.9.9+,且要求设备webview内核Chrome81+、Safari13.7+)

<think>在用户的问题中,用户希望查找在uniapp中判断是否为第一次启动的方法。根据提供的引用,引用[1]提到了判断登录状态,引用[2]和[3]分别提到了iOS和Android原生判断第一次启动的方法,但用户的需求是在uniapp中实现。 因此,我需要结合uniapp的特性来回答。在uniapp中,我们可以使用本地缓存(如uni.setStorageSync和uni.getStorageSync)来存储一个标志,用于记录应用是否是第一次启动。 具体步骤: 1. 在App.vue的onLaunch生命周期函数中,读取本地存储中的一个特定键(例如'isFirstLaunch')的值。 2. 如果该键不存在,说明是第一次启动,则执行相应的操作(例如跳转到引导页或者弹出提示),然后设置该键的值为false(表示已经不是第一次启动)。 3. 如果该键存在,则跳过引导。 注意:由于uniapp跨平台的特性,这种方法在H5、App、小程序等平台都适用。 根据引用[1]中的代码,我们可以模仿其写法,但改为判断是否第一次启动。 下面给出一个示例代码,在App.vue中实现: </think>在 UniApp 中判断应用是否为第一次启动,可以通过本地缓存技术实现。以下是具体实现方法和代码示例: ### 实现原理 1. 应用首次启动时,在本地存储设置一个标识(如 `isFirstLaunch: false`) 2. 每次启动检查该标识: - 若不存在 → 首次启动 - 若存在 → 非首次启动 3. 首次启动后立即更新标识 ### 代码实现 (在 `App.vue` 中) ```javascript export default { onLaunch() { // 检查是否为首次启动 const isFirst = uni.getStorageSync('isFirstLaunch') if (isFirst === '') { // 标识不存在 console.log('首次启动') // 执行首次启动逻辑(如跳转引导页) uni.reLaunch({ url: '/pages/guide/guide' }) // 设置标识(使用同步存储避免异步延迟) uni.setStorageSync('isFirstLaunch', 'launched') } else { console.log('非首次启动') // 正常启动逻辑(如检查登录状态) } } } ``` ### 关键点说明 1. **存储选择**: - 使用 `uni.setStorageSync` 同步API确保标识立即生效 - 替代方案:`uni.setStorage`(异步)可能因延迟导致逻辑错误 2. **标识管理**: - 键名推荐:`isFirstLaunch`(语义化) - 存储值:任意非空字符串(如 `'launched'`) 3. **多平台兼容**: - 此方案在Android/iOS/小程序均可用 - 不需要区分平台(UniApp已封装底层差异) ### 优化建议 1. **清除调试**: 开发时可临时添加清除代码: ```javascript // uni.removeStorageSync('isFirstLaunch') // 调试后注释 ``` 2. **生命周期整合**: 可结合登录判断流程: ```javascript onLaunch() { const isFirst = !uni.getStorageSync('isFirstLaunch') const isLogin = uni.getStorageSync('token') if (isFirst) { uni.reLaunch({ url: '/pages/guide/guide' }) uni.setStorageSync('isFirstLaunch', '1') } else if (!isLogin) { uni.reLaunch({ url: '/pages/login/login' }) } } ``` > **注意**:H5平台需考虑浏览器隐私模式限制(可能无法持久化存储),建议增加异常处理[^1][^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值