儿童绘本馆图书借阅租赁知识付费小程序源码交流
1.分类图书
2.书单推荐
4.会员卡次、期限购买
5.借阅时间选择
6.积分签到
7.优惠Q领取
前端uniapp开发 后端thinkphp开发 完全开源
<template>
<view class="sp-section sp-index">
<!-- search -->
<view class="sp-index__search" @click="jumpTo('pages/index/search')">
<input
type="text"
placeholder="书籍名称/作者名称"
placeholder-class="sp-index__search-desc"
readonly
/>
</view>
<!-- back -->
<view class="sp-index__back"></view>
<!-- banner -->
<view class="sp-index__swiper">
<swiper
:indicator-dots="swiper.indicatorDots"
:autoplay="swiper.autoplay"
:interval="swiper.interval"
:duration="swiper.duration"
>
<swiper-item v-for="(item, $index) in info.rotation_chart" :key="$index">
<image :src="item.rotation_image" @click="jumpToDetail(item)"></image>
</swiper-item>
</swiper>
</view>
<!-- grid -->
<view class="sp-index__menu">
<view
class="sp-index__menu-item"
v-for="(item, $index) in info.age"
:key="$index"
@click="setCategory($index)"
>
<image :src="item.age_img"></image>
<text>{{ item.age }}</text>
</view>
</view>
<!-- ads -->
<view class="sp-index__link">
<view class="sp-index__link-item" @click="jumpTo('pages/mine/member')">
<text>成为会员</text>
<text>畅享多重特权福利</text>
</view>
<view class="sp-index__link-item" @click="jumpTo('pages/mine/article')">
<text>租借流程</text>
<text>便捷租书运送快</text>
</view>
</view>
<!-- ads -->
<view class="sp-index__ad" v-if="info.index_img && info.index_img.index_img">
<image :src="info.index_img.index_img" @click="jumpTo('pages/mine/member')"></image>
</view>
<!-- 推荐书单 -->
<view class="sp-index__boxes">
<view class="sp-index__title">
<text class="sp-index__title-main">推荐书单</text>
<text class="sp-index__title-more" @click="jumpTo('pages/book/series')">更多></text>
</view>
<scroll-view :scroll-x="true" class="sp-index__hot">
<view class="sp-index__hot-item" v-for="(item, $index) in info.book_menu" :key="$index" @click="jumpTo('pages/book/list?id=' + item.id)">
<view class="sp-index__hot-back"></view>
<view class="sp-index__hot-pics">
<image v-for="(book, $book) in item.book_list" :key="$book" :src="book.book_img"></image>
</view>
<view class="sp-index__hot-info">{{ item.menu_name }}</view>
</view>
</scroll-view>
</view>
<!-- 系列精品 -->
<view class="sp-index__boxes">
<view class="sp-index__title">
<text class="sp-index__title-main">系列精品</text>
</view>
<view class="sp-index__list">
<view class="sp-index__list-item" v-for="item in info.book_series" :key="item.id" @click="jumpTo('pages/book/series?id=' + item.id)">
<view class="sp-index__list-info">
<text>{{ item.series_name }}</text>
<text>{{ item.series_synopsis }}</text>
</view>
<view class="sp-index__list-pics">
<image :src="item.series_img"></image>
</view>
</view>
</view>
</view>
<!-- 推荐图书 -->
<view class="sp-index__boxes">
<view class="sp-index__title">
<text class="sp-index__title-main">推荐图书</text>
</view>
<view class="sp-index__goods">
<sp-goods v-for="(item, $index) in info.books" :key="$index" :index="$index" :info="item" />
</view>
</view>
<!-- <section class="sp-groods__row sp-index__goods">
<sp-goods />
</section> -->
<!-- 用户信息 -->
<view class="sp-index__user" v-if="showUsers && !info.users || info.users.age == 0">
<view class="sp-index__user-content">
<view class="sp-index__user-icon"></view>
<image src="../../static/images/index/back.png" mode="widthFix"></image>
<view class="sp-index__user-title">填写宝贝信息</view>
<view class="sp-index__user-form">
<view class="sp-index__user-item">
<label>宝贝昵称</label>
<input type="text" placeholder="请输入宝贝昵称" v-model="user.username">
</view>
<view class="sp-index__user-item">
<label>宝贝性别</label>
<view class="sp-index__user-sex">
<view
class="sp-index__user-man"
:class="{ 'active': user.sex == '男' }"
@click="() => { user.sex = '男' }"
></view>
<view
class="sp-index__user-woman"
:class="{ 'active': user.sex == '女' }"
@click="() => { user.sex = '女' }"
></view>
</view>
</view>
<view class="sp-index__user-item">
<label>宝贝年龄</label>
<input type="text" placeholder="请输入宝贝年龄" v-model="user.age">
</view>
<view class="sp-index__user-type">
<label>喜欢的图书类型</label>
<view class="sp-index__user-classify">
<text
v-for="(item, $index) in navs"
:key="$index"
:class="{ 'checked': item.checked }"
@click="setNavsChecked($index)"
>{{ item.class_name }}</text>
</view>
</view>
</view>
<view class="sp-index__user-button" @click="saveUserInfo">完成</view>
</view>
</view>
<!-- 碳层 -->
<view class="sp-index__mask" v-if="showPopup">
<view class="sp-index__mask-image">
<image :src="info.index_img.index_popup" @click="toPopupDetail"></image>
<view class="sp-index__mask-close" @click="closePopup"></view>
</view>
</view>
<!-- fixed 客服 -->
<sp-contact />
<!-- 登录 -->
<u-popup v-model="show" mode="bottom" borderRadius="24" :closeable="true">
<sp-login v-if="!isUser" @complete="getLoginComplete" />
</u-popup>
</view>
</template>
<script>
export default {
name: 'MemberIndex',
data () {
return {
show: false,
info: {},
isUser: true,
swiper: {
indicatorDots: true,
autoplay: true,
interval: 2000,
duration: 500
},
navs: [],
user: {
username: '',
sex: '',
age: '',
id: ''
},
showUsers: false,
showPopup: false
}
},
onLoad () {
// this.setLogin()
},
onShow () {
// this.getInitData()
const userId = uni.getStorageSync('userId')
this.isUser = userId ? true : false
this.show = userId ? false : true
if (this.isUser) {
this.getInitData(userId)
}
this.getCategory()
setTimeout(() => {
this.showPopup = uni.getStorageSync('showPopup') ? uni.getStorageSync('showPopup') : false
}, 500)
},
created () {},
mounted () {
},
methods: {
// 点击年龄跳转
setCategory (index) {
uni.setStorageSync('ageIndex', index)
uni.switchTab({
url: '/pages/book/category'
})
},
// popup跳转
toPopupDetail () {
uni.navigateTo({
url: this.info.index_img.index_popup_url
})
},
// 关闭popup
closePopup () {
this.showPopup = false
uni.setStorageSync('showPopup', false)
},
// 保存
async saveUserInfo() {
const params = this.user
params.book_interest = this.navs.filter(item => item.checked).map(item => item.id)
if (params.username === '') {
this.$u.toast('请填写宝宝昵称')
return false
}
if (params.sex === '') {
this.$u.toast('请选择宝宝性别')
return false
}
if (params.age === '') {
this.$u.toast('请选择宝宝年龄')
return false
}
if (params.book_interest === '') {
this.$u.toast('请选择图书类型')
return false
}
const userId = uni.getStorageSync('userId')
params.user_id = userId
delete params.id
const { code, data } = await this.$u.api.IndexApi.setModalInfo(params)
console.log('saveUsers', code, data)
if (code === 200) {
const userId = uni.getStorageSync('userId')
this.getInitData(userId)
}
},
// 获取1级分类
async getCategory () {
const { code, data } = await this.$u.api.IndexApi.getFirsetCategory()
if (code === 200) {
this.navs = data.first_class.map(item => {
item.checked = false
return item
})
}
},
setNavsChecked(index) {
this.navs[index].checked = !this.navs[index].checked
},
jumpTo(val) {
this.$u.route(val)
},
// 跳转到书籍详情
jumpToDetail (item) {
// "join_type": 1, // 0=不关联,1=书籍详情,2=推荐书单详情,3=系列精品详情,4=推广页面
if (item.join_type == 0 || item.book_id == 0) {
return false
} else if (item.join_type == 1) {
uni.navigateTo({
url: '/pages/book/detail?id=' + item.book_id
})
} else if (item.join_type == 2) {
uni.navigateTo({
url: '/pages/book/list?id=' + item.book_id
})
} else if (item.join_type == 3) {
uni.navigateTo({
url: '/pages/book/series?id=' + item.book_id
})
} else if (item.join_type == 4) {
uni.navigateTo({
url: '/pages/mine/qrcodeExtension'
})
} else {
return false
}
},
// 出发获取首页
getLoginComplete () {
const userId = uni.getStorageSync('userId')
this.isUser = userId ? true : false
this.show = userId ? false : true
// this.isUser = true
this.getInitData(userId)
},
// 获取首页信息
async getInitData (id) {
const { code, data } = await this.$u.api.IndexApi.getIndexInfo(id)
if (code === 200) {
this.info = data
this.showUsers = this.info.users.age == 0
this.showPopup = this.info.users.age < 1
}
}
},
onShareAppMessage () {}
}
相关文章:

儿童绘本馆图书借阅租赁知识付费小程序源码交流
1.分类图书 2.书单推荐 4.会员卡次、期限购买 5.借阅时间选择 6.积分签到 7.优惠Q领取 前端uniapp开发 后端thinkphp开发 完全开源 <template> <view class"sp-section sp-index"> <!-- search --> <view class&qu…...

Vue3 中 axios 的安装及使用
目录前言:一、什么是 axios ?二、Axios 的配置项三、Axios 的请求方式四、自定义创建实例五、Axios 请求错误处理六、Axios 解决跨域问题七、Axios 请求案例随机笑话大全总结:前言: 在编写vue里的项目时,必须要用和后台…...

Django设计模式以及模板层介绍
MVC和MTV 传统的MVC作用:降低模块间的耦合度(解耦)Django的MTV模式 作用:降低模块间的耦合度(解耦)什么是模板 1、模板是可以根据字典数据动态变化的html网页2、模板可以根据视图中传递的字典数据动态生成相…...

Linux信号一门搞定
1.信号是什么? 信号其实就是一个软件中断。 例: 输入命令,在Shell下启动一个前台进程。用户按下Ctrl-C,键盘输入产生一个硬件中断。如果CPU当前正在执行这个进程的代码,则该进程的用户空间代码暂停执行,…...

手撸一个动态Feign,实现一个“万能”接口调用
Feign,在微服务框架中,是的服务直接的调用变得很简洁、简单,而不需要再编写Java Http调用其他微服务的接口。 动态feign 对于fegin调用,我们一般的用法:为每个微服务都创建对应的feignclient接口,然后为每…...

Linux Capabilities 入门
目录 Linux capabilities 是什么? capabilities 的赋予和继承 线程的 capabilities Permitted Effective Inheritable Bounding Ambient 文件的 capabilities Permitted Inheritable Effective 运行 execve() 后 capabilities 的变化 案例 Linux capab…...

驱动 day6
关于设备树的理解: 设备树(Device Tree)是一种用于特定硬件设备的解释语法树。它用来表示存储有关主板硬件和CPU架构信息的数据在内核中的传递格式,使内核可以更好地了解硬件并支持它们,而不必编写固定的代码。设备节点…...

附录2-tensorflow目标检测
源码来自作者Bubbliiiing,我对参考链接的代码略有修改,网盘地址 链接:百度网盘 请输入提取码 提取码:dvb1 目录 1 参考链接 2 环境 3 数据集准备 3.1 VOCdevkit/VOC2007 3.2 model_data/voc_classes.txt 3.3 voc_an…...

常见的EMC问题
电磁兼容设计的目的就在于满足产品功能要求、减少调试时间,使产品满足电磁兼容标准的要求,并且使产品不会对系统中的其它设备产生电磁干扰。 电磁兼容设计中常见的问题有哪些? 1、电磁兼容设计可以从电路设计(包括器件选择&…...

Redis内存存储效率问题
目录 内存碎片是如何形成的? 如何判断是否有内存碎片? 如何清理内存碎片? INFO命令 面向 Prometheus 的 Redis-exporter 监控 实习期间,了解到,企业级开发中多个项目使用Redis,运行Redis实例的有可能是…...

3.28 haas506 2.0开发教程-example-蓝牙多设备扫描(仅支持M320,HD1)
haas506 2.0开发教程-example-蓝牙多设备扫描案例说明蓝牙信息克隆1.手机蓝牙改名信息克隆代码测试案例说明 开发板扫描蓝牙设备,获取并打印蓝牙设备mac地址。mac地址每个设备不同,且不能更改。本案例仅适用于M320开发板和HD1-RTU。案例使用手机与iBeac…...

C语言经典编程题100例(41~60)
目录41、习题4-4 特殊a串数列求和42、习题4-6 水仙花数43、习题4-7 最大公约数和最小公倍数44、习题7-5 找鞍点45、练习5-1 求m到n之和46、练习5-2 找两个数中最大者47、练习5-3 数字金字塔48、习题5-1 符号函数49、习题5-2 使用函数求奇数和50、习题5-3 使用函数计算两点间的距…...

git日常使用命令
实习这段时间使用了很多git指令来提交代码,简单记录一下日常使用的指令: 提交代码通常顺序: 1.git status 查看本地修改项 2.git add . 提交全部文件 (这个 .是全部文件)到暂存区 3.git commit -m ‘本次提交的说明’…...

ES6对象展开运算符浅拷贝or深拷贝
ES6中提出的对象展开运算符“…”就是用来展开元素的。有了它就不用代码循环遍历了,偷懒专用。 1. 合并数组 展开原有数组中的所有元素,可以合并成一个新的数组。 var a[1,2,3]; var b[4,5,6]; var c[...a,...b]; console.log(c) // 输出:…...

leaflet 上传包含shp的zip文件,在map上解析显示图形(059)
第059个 点击查看专栏目录 本示例的目的是介绍演示如何在vue+leaflet中本地上传包含shp的zip文件,利用shapefile读取shp数据,并在地图上显示图形。 直接复制下面的 vue+openlayers源代码,操作2分钟即可运行实现效果 文章目录 示例效果加载shapefile.js方式安装引用jszip(…...

CAN总线详细介绍
1.1 CAN是什么? CAN 最终成为国际标准 ( ISO11898(高速应用)和 ISO11519(低速应用)),是国际上应用最广泛的现场总线之一。 1.2 CAN总线特点 多主方式: 可以多主方式工作,网络上任意一个节点…...

python如何完成对 Excel文件的解密后读取?
通常为了防止重要的Excel文件数据内容的泄露,需要对文件整体进行加密与解密的操作。 对于文件的加解密过程,python也有很多非标准库来帮助我们完成操作,这里主要说明如何完成对Excel文件的解密与读取操作。 这里我们使用到的是msoffcrypto-…...

微服务实战--高级篇:RabbitMQ高级
服务异步通信-高级篇 消息队列在使用过程中,面临着很多实际问题需要思考: 1.消息可靠性 消息从发送,到消费者接收,会经理多个过程: 其中的每一步都可能导致消息丢失,常见的丢失原因包括: 发送…...

autoCAD2022 - 设置新的原点
文章目录autoCAD2022 - 设置新的原点概述笔记UCS原点设置功能的菜单位置ENDautoCAD2022 - 设置新的原点 概述 上次整板子的dxf时, 原来的原点不合适, 想调整一下. 当时整完了, 没记录. 这次用的时候, 又找半天… 设置新原点的功能, 不在顶部菜单中, 而是在视图右上角的UCS图标…...

spring boot 配置 mybatis-plus多数据源
简介Mybatis-puls 多数据源的使用,采用的是官方提供的dynamic-datasource-spring-boot-starter包的 DS 注解,具体可以参考官网:https://gitee.com/baomidou/dynamic-datasource-spring-boot-starterpom.xml文件引入如下依赖主要引入dynamic-d…...

独立产品灵感周刊 DecoHack #047 - 安卓手机上最有用的APP
本周刊记录有趣好玩的独立产品设计开发相关内容,每周发布,往期内容同样精彩,感兴趣的伙伴可以点击订阅我的周刊。为保证每期都能收到,建议邮件订阅。欢迎通过 Twitter 私信推荐或投稿。💻 产品推荐 1. Bouncer Tempor…...

【面试题】JavaScript中递归的理解
大厂面试题分享 面试题库后端面试题库 (面试必备) 推荐:★★★★★地址:前端面试题库递归 RecursionTo iterate is human, to recurse, divine. 理解迭代,神理解递归。本文会以 JavaScript为主、有部分 Rust 举例说明。…...

PyTorch学习笔记
PyTorch学习笔记(一):PyTorch环境安装 往期学习资料推荐: 1.Pytorch实战笔记_GoAI的博客-CSDN博客 2.Pytorch入门教程_GoAI的博客-CSDN博客 安装参考: 1.视频教程:3分钟深度学习【环境搭建】CUDA Anacon…...

SpringBoot2知识点记录
SpringBoot2知识点记录1.SpringBoot2基础入门1.1 环境要求1.1.1 maven设置1.2 第一个程序 HelloWorld1.2.1 创建maven工程1.2.2 引入依赖1.2.3 创建主程序1.2.4 编写业务1.2.5 测试1.2.6 简化配置1.2.7 简化部署1.3 自动装配1.3.1 SpringBoot特点1.3.1.1 依赖管理1.3.1.2 自动装…...

Mysql
1 Sql编写 count(*) //是对行数目进行计数 count(column_name) //是对列中不为空的行进行计数 SELECT COUNT( DISTINCT id ) FROM tablename; //计算表中id不同的记录有多少条 SELECT DISTINCT id, type FROM tablename; //返回表中id与type同时不同的结果 X.1 连表子查询 sel…...

Q4营收利润增长背后估值持续偏低,全球支付巨头PayPal前景如何?
作为国际版的“支付宝”,全球第三方支付巨头PayPal的业务横跨欧美市场,覆盖了全球200多个国家和地区。同时,PayPal也是首家进军中国支付市场的外资机构,实力强劲。然而,近两年,PayPal的市值一路从3000亿跌至…...

【自然语言处理】【大模型】BLOOM:一个176B参数且可开放获取的多语言模型
BLOOM:一个176B参数且可开放获取的多语言模型《BLOOM: A 176B-Parameter Open-Access Multilingual Language Model》论文地址:https://arxiv.org/pdf/2211.05100.pdf 相关博客 【自然语言处理】【大模型】用于大型Transformer的8-bit矩阵乘法介绍 【自然…...

小红书穿搭博主推广费用是多少?
小红书作为一个种草属性非常强的平台,商业价值是有目共睹的。很多爱美的女性都会在小红书上被种草某个商品,所以很多服装品牌都会在小红书上布局推广。 穿搭作为小红书的顶梁柱类目,刷小红书就能总是看到好看的穿搭博主分享美美的衣服&#…...

网络安全-PHPstudy环境搭建
网络安全-PHPstudy环境搭建 网络搭建我是专家,安全我懂的不多,所以可能很基础。。因为我自己都不懂,都是跟着课程学的 PHPstudy 这个东东是一个在windwos下可以快速部署的web开发环境,安装了就能用,也支持iis和ngin…...

operator的两种用法(重载和隐式类型转换)
文章目录重载隐式类型转换构造函数的隐式类型转换补充operator算子的隐式类型转换重载 略 隐式类型转换 构造函数的隐式类型转换 利用operator进行的隐式类型转换成为operator算子的隐式类型转换,讲这个之前先了解构造函数的隐式类型转换,请看以下代…...