对比新文件 |
| | |
| | | { // launch.json 配置了启动调试时相关设置,configurations下节点名称可为 app-plus/h5/mp-weixin/mp-baidu/mp-alipay/mp-qq/mp-toutiao/mp-360/ |
| | | // launchtype项可配置值为local或remote, local代表前端连本地云函数,remote代表前端连云端云函数 |
| | | "version": "0.0", |
| | | "configurations": [{ |
| | | "default" : |
| | | { |
| | | "launchtype" : "local" |
| | | }, |
| | | "mp-weixin" : |
| | | { |
| | | "launchtype" : "local" |
| | | }, |
| | | "type" : "uniCloud" |
| | | } |
| | | ] |
| | | } |
对比新文件 |
| | |
| | | { |
| | | "name": "water-drinking-uniapp", |
| | | "lockfileVersion": 3, |
| | | "requires": true, |
| | | "packages": {} |
| | | } |
对比新文件 |
| | |
| | | { |
| | | "name": "water-drinking-uniapp", |
| | | "version": "1.0.0", |
| | | "description": "", |
| | | "main": "main.js", |
| | | "dependencies":{ |
| | | "@dcloudio/uni-ui": "^1.4.28" |
| | | }, |
| | | "devDependencies": {}, |
| | | "scripts": { |
| | | "test": "echo \"Error: no test specified\" && exit 1" |
| | | }, |
| | | "keywords": [], |
| | | "author": "", |
| | | "license": "ISC" |
| | | } |
| | |
| | | { |
| | | "path": "pages/index/index", |
| | | "style": { |
| | | "navigationBarTitleText": "uni-app" |
| | | "navigationStyle":"custom" |
| | | } |
| | | }, |
| | | { |
| | | "path": "pages/login/index", |
| | | "style": { |
| | | "navigationStyle":"custom" |
| | | } |
| | | } |
| | | ], |
| | | "globalStyle": { |
| | | "navigationBarTextStyle": "black", |
| | | "navigationBarTitleText": "uni-app", |
| | | "navigationBarBackgroundColor": "#F8F8F8", |
| | | "backgroundColor": "#F8F8F8" |
| | | // "navigationBarTextStyle": "black", |
| | | // "navigationBarTitleText": "uni-app", |
| | | // "navigationBarBackgroundColor": "#F8F8F8", |
| | | // "backgroundColor": "#F8F8F8", |
| | | "navigationStyle": "custom" |
| | | }, |
| | | "uniIdRouter": {} |
| | | // "uniIdRouter": {}, |
| | | "easycom": { |
| | | "autoscan": true, |
| | | "custom": { |
| | | // uni-ui 规则如下配置 |
| | | "^uni-(.*)": "@dcloudio/uni-ui/lib/uni-$1/uni-$1.vue" |
| | | } |
| | | } |
| | | } |
| | |
| | | import { onMounted } from "vue" |
| | | |
| | | <template> |
| | | <view class="content"> |
| | | <image class="logo" src="/static/logo.png"></image> |
| | | <view class="text-area"> |
| | | <text class="title">{{title}}</text> |
| | | <view class="container"> |
| | | <view class="content"> |
| | | <view class="card-box" :style="{paddingTop:capsuleHeight + 'rpx'}"> |
| | | <view class="card"></view> |
| | | </view> |
| | | <view class="function-box1"> |
| | | <view class="box1-bg"></view> |
| | | <view class="box1-bg"></view> |
| | | <view class="box1-bg"></view> |
| | | </view> |
| | | <view class="function-box2"> |
| | | <view class="box2-title"><text>功能列表</text></view> |
| | | <view class="box2-content"> |
| | | <block v-for="(item,index) in functionList" :key="index"> |
| | | <view class="box2-item" @click="navTo(item.url)"> |
| | | <image :src= "item.icon" alt=""></image> |
| | | <view class="box2-item-text">{{item.text}}</view> |
| | | </view> |
| | | </block> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | <button @click="back()"></button> |
| | | </view> |
| | | </template> |
| | | |
| | | <script> |
| | | export default { |
| | | data() { |
| | | return { |
| | | title: 'Hello' |
| | | } |
| | | }, |
| | | onLoad() { |
| | | |
| | | }, |
| | | methods: { |
| | | |
| | | } |
| | | <script setup> |
| | | import { onMounted, ref } from "vue" |
| | | const back = () =>{ |
| | | // uni.navigateBack() |
| | | uni.navigateTo({ |
| | | url:"/pages/login/index" |
| | | }) |
| | | } |
| | | //胶囊高度 |
| | | const capsuleHeight = ref(0) |
| | | onMounted(() =>{ |
| | | if(uni.getMenuButtonBoundingClientRect){ |
| | | capsuleHeight.value = (uni.getMenuButtonBoundingClientRect().top + uni.getMenuButtonBoundingClientRect().height) * 2 |
| | | } |
| | | }) |
| | | /** |
| | | * 功能列表相关 |
| | | */ |
| | | const functionList = ref([ |
| | | {text:'余额',icon:'../../static/images/index/icon31.png',url:'/pages/login/index'}, |
| | | {text:'余额',icon:'../../static/images/index/icon32.png',url:'/pages/login/index'}, |
| | | {text:'余额',icon:'../../static/images/index/icon33.png',url:'/pages/login/index'}, |
| | | {text:'余额',icon:'../../static/images/index/icon34.png',url:'/pages/login/index'}, |
| | | {text:'余额',icon:'../../static/images/index/icon35.png',url:'/pages/login/index'}, |
| | | {text:'余额',icon:'../../static/images/index/icon36.png',url:'/pages/login/index'}, |
| | | {text:'余额',icon:'../../static/images/index/icon37.png',url:'/pages/login/index'}, |
| | | {text:'余额',icon:'../../static/images/index/icon38.png',url:'/pages/login/index'}, |
| | | ]) |
| | | |
| | | </script> |
| | | |
| | | <style> |
| | | .content { |
| | | <style lang="scss" scoped> |
| | | .container{ |
| | | width:100%; |
| | | height:100vh; |
| | | overflow:scroll; |
| | | .content{ |
| | | width:100%; |
| | | height:100vh; |
| | | background:#F6F6F6; |
| | | } |
| | | } |
| | | .card-box{ |
| | | width: 100%; |
| | | height: auto; |
| | | // background: #a0b5c7; |
| | | box-sizing: border-box; |
| | | padding: 0 32rpx; |
| | | background: linear-gradient(to bottom,#5EA1FA,#D2F2FE); |
| | | .card{ |
| | | width: 100%; |
| | | height: 304rpx; |
| | | background-image: url("../../static/images/index/card1.png"); |
| | | background-repeat: no-repeat; |
| | | background-size: 100%; |
| | | |
| | | } |
| | | } |
| | | .function-box1{ |
| | | width:100%; |
| | | box-sizing:border-box; |
| | | height: 264rpx; |
| | | padding: 32rpx; |
| | | // background: rgba(85, 170, 0, 0.1); |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | justify-content: center; |
| | | .box1-bg{ |
| | | width:212rpx; |
| | | height:200rpx; |
| | | border-radius:24rpx; |
| | | background: #fff; |
| | | box-shadow:0 0 12rpx 2rpx rgba(13,118,255,0.16); |
| | | } |
| | | } |
| | | |
| | | .logo { |
| | | height: 200rpx; |
| | | width: 200rpx; |
| | | margin-top: 200rpx; |
| | | margin-left: auto; |
| | | margin-right: auto; |
| | | margin-bottom: 50rpx; |
| | | .function-box2{ |
| | | width:100%; |
| | | box-sizing:border-box; |
| | | height: 460rpx;//374 + 44 + 距离 + 底部padding32 |
| | | padding:0 32rpx 32rpx; |
| | | // background: rgba(46, 121, 170, 0.5); |
| | | .box2-title{ |
| | | width: 100%; |
| | | font-weight:300; |
| | | font-size: 32rpx; |
| | | color: #000000; |
| | | text-align: left; |
| | | margin-bottom: 10rpx; |
| | | margin-left: 30rpx; |
| | | } |
| | | .box2-content{ |
| | | box-sizing: border-box; |
| | | padding:30rpx 50rpx; |
| | | width: 686rpx; |
| | | height:374rpx; |
| | | background: #fff; |
| | | border-radius: 24rpx; |
| | | box-shadow: 0 0 12rpx 2rpx rgba(0, 0, 0, 0.1); |
| | | display: flex; |
| | | flex-wrap: wrap; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | .box2-item{ |
| | | width: 120rpx; |
| | | height:130rpx; |
| | | image{ |
| | | width: 90rpx; |
| | | height:90rpx; |
| | | margin: 0 auto; |
| | | } |
| | | .box2-item-text{ |
| | | width:100%; |
| | | height: 40rpx; |
| | | font-weight: 300; |
| | | font-size: 28rpx; |
| | | color: #000000; |
| | | text-align: center; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .text-area { |
| | | display: flex; |
| | | justify-content: center; |
| | | } |
| | | |
| | | .title { |
| | | font-size: 36rpx; |
| | | color: #8f8f94; |
| | | button{ |
| | | width:100rpx; |
| | | height:50rpx |
| | | } |
| | | </style> |
对比新文件 |
| | |
| | | |
| | | <script setup> |
| | | import { onMounted, ref } from "vue" |
| | | // 微信授权登录相关 |
| | | let popupRef = ref(null) |
| | | const login = () =>{ |
| | | uni.navigateTo({ |
| | | url:"/pages/index/index" |
| | | }) |
| | | console.log('login1') |
| | | } |
| | | const wxLoginPopup = () =>{ |
| | | popupRef.value.open('bottom') |
| | | } |
| | | const wxLoginFn = () =>{ |
| | | console.log('login2') |
| | | popupRef.value.close('bottom') |
| | | } |
| | | </script> |
| | | <template> |
| | | <view class="container"> |
| | | <view class="content"> |
| | | <view class="title"> |
| | | <view class= 'text1'>欢迎登录</view> |
| | | <view class= 'text2'>Welcome to login</view> |
| | | </view> |
| | | <view class="form"> |
| | | <view class='form-input'><input type="text" placeholder="输入账号"></input></view> |
| | | <view class="form-input"><input password type="text" placeholder="输入密码"></input></view> |
| | | </view> |
| | | <view class="login-btn"> |
| | | <button @click = login()>登录</button> |
| | | </view> |
| | | <view class="bottom"> |
| | | <view class="divide"> |
| | | <view class="line"></view> |
| | | <view class="divide-text">第三方账号登录</view> |
| | | <view class="line"></view> |
| | | </view> |
| | | <view class="other-login"> |
| | | <img src="../../static/images/login/wechat.png" alt="" @click="wxLoginPopup()"/> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | <!-- 微信授权弹窗 --> |
| | | <uni-popup ref="popupRef" background-color="#fff"> |
| | | <view class="popup-content"> |
| | | <text class="popup-title">微信登录</text> |
| | | <view class="hr"></view> |
| | | <view class="img-box"><img src="../../static/images/login/logo.png" alt="" class="img"/></view> |
| | | <view class="info-box"> |
| | | <view class="info-text1">青源直饮水平台申请获取以下权限:</view> |
| | | <view class="hr2"></view> |
| | | <view class="info-text2">· 获得你的公开信息(昵称、头像、地区及性别)</view> |
| | | <view class="button-box"> |
| | | <button class="button1" @click="popupRef.close('bottom')">取消</button> |
| | | <button class="button2" @click="wxLoginFn()">确定</button> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | </uni-popup> |
| | | </view> |
| | | </template> |
| | | |
| | | <style lang ="scss"> |
| | | page { |
| | | width: 100%; |
| | | height:100%; |
| | | } |
| | | .container{ |
| | | width:100%; |
| | | height:100%; |
| | | background-image:url('../../static/images/login/bg2.png'); |
| | | background-size: 100%; |
| | | background-repeat: no-repeat; |
| | | position: relative; |
| | | .content{ |
| | | position: absolute; |
| | | width:680rpx; |
| | | height:1080rpx; |
| | | top:22%; |
| | | left:calc(50% - 340rpx); |
| | | background-image:url('../../static/images/login/content-bg.png'); |
| | | background-repeat: no-repeat; |
| | | background-size: 100%; |
| | | .title{ |
| | | width:100%; |
| | | height:180rpx; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: flex-start; |
| | | padding: 9% 0 0 13%; |
| | | box-sizing:border-box; |
| | | .text1{ |
| | | width:250rpx; |
| | | font-weight: 500; |
| | | font-size: 56rpx; |
| | | color: #345DB1; |
| | | text-align: left; |
| | | margin-left:14rpx; |
| | | margin-bottom:20rpx; |
| | | } |
| | | .text2{ |
| | | width:500rpx; |
| | | font-weight: 400; |
| | | font-size: 36rpx; |
| | | color: #9AB6DD; |
| | | text-align: left; |
| | | } |
| | | } |
| | | .form{ |
| | | width:100%; |
| | | height:260rpx; |
| | | margin-top: 125rpx; |
| | | /* background-color: #345DB1; */ |
| | | box-sizing:border-box; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: space-between; |
| | | .form-input{ |
| | | width:582rpx; |
| | | height:100rpx; |
| | | background-image: url('../../static/images/login/input1.png'); |
| | | background-repeat: no-repeat; |
| | | background-size: 100%; |
| | | background-position: center; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content:flex-start; |
| | | margin: 0 auto; |
| | | :deep(.uni-input-placeholder ){ |
| | | color: #9DC4E8; |
| | | } |
| | | input{ |
| | | width:80%; |
| | | margin-left:60rpx; |
| | | font-weight: 400; |
| | | font-size: 32rpx; |
| | | text-align: left; |
| | | color: #2b4e82; |
| | | } |
| | | } |
| | | } |
| | | .login-btn{ |
| | | width:530rpx; |
| | | height:100rpx; |
| | | margin: 80rpx auto 60rpx; |
| | | button{ |
| | | background:linear-gradient(to right,#51C9F6,#4E9BFF); |
| | | font-weight: 500; |
| | | font-size: 36rpx; |
| | | color: #FFFFFF; |
| | | border-radius: 20rpx; |
| | | } |
| | | } |
| | | .bottom{ |
| | | width:100%; |
| | | height:180rpx; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | .divide{ |
| | | box-sizing:border-box; |
| | | width: 100%; |
| | | display:flex; |
| | | justify-content: space-between; |
| | | align-items:center; |
| | | padding:0 85rpx; |
| | | /* background: #446f52; */ |
| | | .line{ |
| | | width:125rpx; |
| | | height:2rpx; |
| | | background:#959595; |
| | | } |
| | | .divide-text{ |
| | | font-weight: 600; |
| | | font-size: 28rpx; |
| | | color: #B9B9B9; |
| | | text-align: center; |
| | | } |
| | | } |
| | | .other-login{ |
| | | box-sizing:border-box; |
| | | width:100%; |
| | | height:100rpx; |
| | | /* background: #5d7682; */ |
| | | padding:0 90rpx; |
| | | display: flex; |
| | | justify-content:center; |
| | | align-items: center; |
| | | img{ |
| | | width:76rpx; |
| | | height:76rpx; |
| | | /* background: #345DB1; */ |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .popup-content { |
| | | height: 560rpx; |
| | | position: relative; |
| | | z-index: 1000; |
| | | .popup-title{ |
| | | width: 100%; |
| | | display: block; |
| | | text-align: center; |
| | | margin: 15rpx 0; |
| | | font-weight: 600; |
| | | font-size: 36rpx; |
| | | } |
| | | .hr { |
| | | width: 100%; |
| | | height: 2rpx; |
| | | background: #e2e2e2; |
| | | } |
| | | .img-box { |
| | | width: 65rpx; |
| | | height: 65rpx; |
| | | margin: 40rpx auto 30rpx; |
| | | border: 1rpx solid #e2e2e2; |
| | | border-radius: 50%; |
| | | padding: 15rpx; |
| | | .img{ |
| | | width: 100%; |
| | | height: 100%; |
| | | } |
| | | } |
| | | .info-box { |
| | | width: 100%; |
| | | padding: 0 80rpx; |
| | | box-sizing: border-box; |
| | | .hr2{ |
| | | width: 100%; |
| | | height: 2rpx; |
| | | background: #e2e2e2; |
| | | margin: 20rpx 0; |
| | | } |
| | | .info-text2{ |
| | | font-size: 26rpx; |
| | | color: #767676; |
| | | } |
| | | } |
| | | .button-box{ |
| | | display: flex; |
| | | margin-top: 20rpx; |
| | | button{ |
| | | width: 230rpx; |
| | | height: 80rpx; |
| | | line-height: 80rpx; |
| | | border: none; |
| | | box-shadow: none; |
| | | margin-top: 30rpx; |
| | | } |
| | | button::after { |
| | | border: none !important; |
| | | } |
| | | .button1{ |
| | | background-color: #F0F0F0; |
| | | color: #333333; |
| | | } |
| | | .button2{ |
| | | background-color: #06BF5E; |
| | | color: #ffffff; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | </style> |
| | |
| | | { |
| | | "hash": "b68c4d1e", |
| | | "configHash": "d5ed2199", |
| | | "lockfileHash": "e3b0c442", |
| | | "browserHash": "6500e178", |
| | | "hash": "bb2e2c43", |
| | | "configHash": "539dec94", |
| | | "lockfileHash": "f3d35e11", |
| | | "browserHash": "ee67bce4", |
| | | "optimized": {}, |
| | | "chunks": {} |
| | | } |
对比新文件 |
| | |
| | | "use strict"; |
| | | Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" }); |
| | | const common_vendor = require("./common/vendor.js"); |
| | | if (!Math) { |
| | | "./pages/index/index.js"; |
| | | "./pages/login/index.js"; |
| | | } |
| | | const _sfc_main = { |
| | | __name: "App", |
| | | setup(__props) { |
| | | common_vendor.onLaunch(() => { |
| | | console.log("App Launch"); |
| | | }); |
| | | common_vendor.onShow(() => { |
| | | console.log("App Show"); |
| | | }); |
| | | common_vendor.onHide(() => { |
| | | console.log("App Hide"); |
| | | }); |
| | | return () => { |
| | | }; |
| | | } |
| | | }; |
| | | function createApp() { |
| | | const app = common_vendor.createSSRApp(_sfc_main); |
| | | return { |
| | | app |
| | | }; |
| | | } |
| | | createApp().app.mount("#app"); |
| | | exports.createApp = createApp; |
对比新文件 |
| | |
| | | { |
| | | "pages": [ |
| | | "pages/index/index", |
| | | "pages/login/index" |
| | | ], |
| | | "window": { |
| | | "navigationStyle": "custom" |
| | | }, |
| | | "usingComponents": {} |
| | | } |
对比新文件 |
| | |
| | | |
| | | /*每个页面公共css */ |
| | | page{--status-bar-height:25px;--top-window-height:0px;--window-top:0px;--window-bottom:0px;--window-left:0px;--window-right:0px;--window-magin:0px}[data-c-h="true"]{display: none !important;} |
对比新文件 |
| | |
| | | "use strict"; |
| | | const _imports_0 = "/static/images/login/wechat.png"; |
| | | const _imports_1 = "/static/images/login/logo.png"; |
| | | exports._imports_0 = _imports_0; |
| | | exports._imports_1 = _imports_1; |
对比新文件 |
| | |
| | | "use strict"; |
| | | const common_vendor = require("../../../../../common/vendor.js"); |
| | | const _sfc_main = { |
| | | name: "uniPopup", |
| | | components: {}, |
| | | emits: ["change", "maskClick"], |
| | | props: { |
| | | // 开启动画 |
| | | animation: { |
| | | type: Boolean, |
| | | default: true |
| | | }, |
| | | // 弹出层类型,可选值,top: 顶部弹出层;bottom:底部弹出层;center:全屏弹出层 |
| | | // message: 消息提示 ; dialog : 对话框 |
| | | type: { |
| | | type: String, |
| | | default: "center" |
| | | }, |
| | | // maskClick |
| | | isMaskClick: { |
| | | type: Boolean, |
| | | default: null |
| | | }, |
| | | // TODO 2 个版本后废弃属性 ,使用 isMaskClick |
| | | maskClick: { |
| | | type: Boolean, |
| | | default: null |
| | | }, |
| | | backgroundColor: { |
| | | type: String, |
| | | default: "none" |
| | | }, |
| | | safeArea: { |
| | | type: Boolean, |
| | | default: true |
| | | }, |
| | | maskBackgroundColor: { |
| | | type: String, |
| | | default: "rgba(0, 0, 0, 0.4)" |
| | | }, |
| | | borderRadius: { |
| | | type: String |
| | | } |
| | | }, |
| | | watch: { |
| | | /** |
| | | * 监听type类型 |
| | | */ |
| | | type: { |
| | | handler: function(type) { |
| | | if (!this.config[type]) |
| | | return; |
| | | this[this.config[type]](true); |
| | | }, |
| | | immediate: true |
| | | }, |
| | | isDesktop: { |
| | | handler: function(newVal) { |
| | | if (!this.config[newVal]) |
| | | return; |
| | | this[this.config[this.type]](true); |
| | | }, |
| | | immediate: true |
| | | }, |
| | | /** |
| | | * 监听遮罩是否可点击 |
| | | * @param {Object} val |
| | | */ |
| | | maskClick: { |
| | | handler: function(val) { |
| | | this.mkclick = val; |
| | | }, |
| | | immediate: true |
| | | }, |
| | | isMaskClick: { |
| | | handler: function(val) { |
| | | this.mkclick = val; |
| | | }, |
| | | immediate: true |
| | | }, |
| | | // H5 下禁止底部滚动 |
| | | showPopup(show) { |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | duration: 300, |
| | | ani: [], |
| | | showPopup: false, |
| | | showTrans: false, |
| | | popupWidth: 0, |
| | | popupHeight: 0, |
| | | config: { |
| | | top: "top", |
| | | bottom: "bottom", |
| | | center: "center", |
| | | left: "left", |
| | | right: "right", |
| | | message: "top", |
| | | dialog: "center", |
| | | share: "bottom" |
| | | }, |
| | | maskClass: { |
| | | position: "fixed", |
| | | bottom: 0, |
| | | top: 0, |
| | | left: 0, |
| | | right: 0, |
| | | backgroundColor: "rgba(0, 0, 0, 0.4)" |
| | | }, |
| | | transClass: { |
| | | backgroundColor: "transparent", |
| | | borderRadius: this.borderRadius || "0", |
| | | position: "fixed", |
| | | left: 0, |
| | | right: 0 |
| | | }, |
| | | maskShow: true, |
| | | mkclick: true, |
| | | popupstyle: "top" |
| | | }; |
| | | }, |
| | | computed: { |
| | | getStyles() { |
| | | let res = { backgroundColor: this.bg }; |
| | | if (this.borderRadius || "0") { |
| | | res = Object.assign(res, { borderRadius: this.borderRadius }); |
| | | } |
| | | return res; |
| | | }, |
| | | isDesktop() { |
| | | return this.popupWidth >= 500 && this.popupHeight >= 500; |
| | | }, |
| | | bg() { |
| | | if (this.backgroundColor === "" || this.backgroundColor === "none") { |
| | | return "transparent"; |
| | | } |
| | | return this.backgroundColor; |
| | | } |
| | | }, |
| | | mounted() { |
| | | const fixSize = () => { |
| | | const { |
| | | windowWidth, |
| | | windowHeight, |
| | | windowTop, |
| | | safeArea, |
| | | screenHeight, |
| | | safeAreaInsets |
| | | } = common_vendor.index.getSystemInfoSync(); |
| | | this.popupWidth = windowWidth; |
| | | this.popupHeight = windowHeight + (windowTop || 0); |
| | | if (safeArea && this.safeArea) { |
| | | this.safeAreaInsets = screenHeight - safeArea.bottom; |
| | | } else { |
| | | this.safeAreaInsets = 0; |
| | | } |
| | | }; |
| | | fixSize(); |
| | | }, |
| | | // TODO vue3 |
| | | unmounted() { |
| | | this.setH5Visible(); |
| | | }, |
| | | activated() { |
| | | this.setH5Visible(!this.showPopup); |
| | | }, |
| | | deactivated() { |
| | | this.setH5Visible(true); |
| | | }, |
| | | created() { |
| | | if (this.isMaskClick === null && this.maskClick === null) { |
| | | this.mkclick = true; |
| | | } else { |
| | | this.mkclick = this.isMaskClick !== null ? this.isMaskClick : this.maskClick; |
| | | } |
| | | if (this.animation) { |
| | | this.duration = 300; |
| | | } else { |
| | | this.duration = 0; |
| | | } |
| | | this.messageChild = null; |
| | | this.clearPropagation = false; |
| | | this.maskClass.backgroundColor = this.maskBackgroundColor; |
| | | }, |
| | | methods: { |
| | | setH5Visible(visible = true) { |
| | | }, |
| | | /** |
| | | * 公用方法,不显示遮罩层 |
| | | */ |
| | | closeMask() { |
| | | this.maskShow = false; |
| | | }, |
| | | /** |
| | | * 公用方法,遮罩层禁止点击 |
| | | */ |
| | | disableMask() { |
| | | this.mkclick = false; |
| | | }, |
| | | // TODO nvue 取消冒泡 |
| | | clear(e) { |
| | | e.stopPropagation(); |
| | | this.clearPropagation = true; |
| | | }, |
| | | open(direction) { |
| | | if (this.showPopup) { |
| | | return; |
| | | } |
| | | let innerType = ["top", "center", "bottom", "left", "right", "message", "dialog", "share"]; |
| | | if (!(direction && innerType.indexOf(direction) !== -1)) { |
| | | direction = this.type; |
| | | } |
| | | if (!this.config[direction]) { |
| | | console.error("缺少类型:", direction); |
| | | return; |
| | | } |
| | | this[this.config[direction]](); |
| | | this.$emit("change", { |
| | | show: true, |
| | | type: direction |
| | | }); |
| | | }, |
| | | close(type) { |
| | | this.showTrans = false; |
| | | this.$emit("change", { |
| | | show: false, |
| | | type: this.type |
| | | }); |
| | | clearTimeout(this.timer); |
| | | this.timer = setTimeout(() => { |
| | | this.showPopup = false; |
| | | }, 300); |
| | | }, |
| | | // TODO 处理冒泡事件,头条的冒泡事件有问题 ,先这样兼容 |
| | | touchstart() { |
| | | this.clearPropagation = false; |
| | | }, |
| | | onTap() { |
| | | if (this.clearPropagation) { |
| | | this.clearPropagation = false; |
| | | return; |
| | | } |
| | | this.$emit("maskClick"); |
| | | if (!this.mkclick) |
| | | return; |
| | | this.close(); |
| | | }, |
| | | /** |
| | | * 顶部弹出样式处理 |
| | | */ |
| | | top(type) { |
| | | this.popupstyle = this.isDesktop ? "fixforpc-top" : "top"; |
| | | this.ani = ["slide-top"]; |
| | | this.transClass = { |
| | | position: "fixed", |
| | | left: 0, |
| | | right: 0, |
| | | backgroundColor: this.bg, |
| | | borderRadius: this.borderRadius || "0" |
| | | }; |
| | | if (type) |
| | | return; |
| | | this.showPopup = true; |
| | | this.showTrans = true; |
| | | this.$nextTick(() => { |
| | | if (this.messageChild && this.type === "message") { |
| | | this.messageChild.timerClose(); |
| | | } |
| | | }); |
| | | }, |
| | | /** |
| | | * 底部弹出样式处理 |
| | | */ |
| | | bottom(type) { |
| | | this.popupstyle = "bottom"; |
| | | this.ani = ["slide-bottom"]; |
| | | this.transClass = { |
| | | position: "fixed", |
| | | left: 0, |
| | | right: 0, |
| | | bottom: 0, |
| | | paddingBottom: this.safeAreaInsets + "px", |
| | | backgroundColor: this.bg, |
| | | borderRadius: this.borderRadius || "0" |
| | | }; |
| | | if (type) |
| | | return; |
| | | this.showPopup = true; |
| | | this.showTrans = true; |
| | | }, |
| | | /** |
| | | * 中间弹出样式处理 |
| | | */ |
| | | center(type) { |
| | | this.popupstyle = "center"; |
| | | this.ani = ["fade"]; |
| | | this.transClass = { |
| | | position: "fixed", |
| | | display: "flex", |
| | | flexDirection: "column", |
| | | bottom: 0, |
| | | left: 0, |
| | | right: 0, |
| | | top: 0, |
| | | justifyContent: "center", |
| | | alignItems: "center", |
| | | borderRadius: this.borderRadius || "0" |
| | | }; |
| | | if (type) |
| | | return; |
| | | this.showPopup = true; |
| | | this.showTrans = true; |
| | | }, |
| | | left(type) { |
| | | this.popupstyle = "left"; |
| | | this.ani = ["slide-left"]; |
| | | this.transClass = { |
| | | position: "fixed", |
| | | left: 0, |
| | | bottom: 0, |
| | | top: 0, |
| | | backgroundColor: this.bg, |
| | | borderRadius: this.borderRadius || "0", |
| | | display: "flex", |
| | | flexDirection: "column" |
| | | }; |
| | | if (type) |
| | | return; |
| | | this.showPopup = true; |
| | | this.showTrans = true; |
| | | }, |
| | | right(type) { |
| | | this.popupstyle = "right"; |
| | | this.ani = ["slide-right"]; |
| | | this.transClass = { |
| | | position: "fixed", |
| | | bottom: 0, |
| | | right: 0, |
| | | top: 0, |
| | | backgroundColor: this.bg, |
| | | borderRadius: this.borderRadius || "0", |
| | | display: "flex", |
| | | flexDirection: "column" |
| | | }; |
| | | if (type) |
| | | return; |
| | | this.showPopup = true; |
| | | this.showTrans = true; |
| | | } |
| | | } |
| | | }; |
| | | if (!Array) { |
| | | const _easycom_uni_transition2 = common_vendor.resolveComponent("uni-transition"); |
| | | _easycom_uni_transition2(); |
| | | } |
| | | const _easycom_uni_transition = () => "../uni-transition/uni-transition.js"; |
| | | if (!Math) { |
| | | _easycom_uni_transition(); |
| | | } |
| | | function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { |
| | | return common_vendor.e({ |
| | | a: $data.showPopup |
| | | }, $data.showPopup ? common_vendor.e({ |
| | | b: $data.maskShow |
| | | }, $data.maskShow ? { |
| | | c: common_vendor.o($options.onTap), |
| | | d: common_vendor.p({ |
| | | name: "mask", |
| | | ["mode-class"]: "fade", |
| | | styles: $data.maskClass, |
| | | duration: $data.duration, |
| | | show: $data.showTrans |
| | | }) |
| | | } : {}, { |
| | | e: common_vendor.s($options.getStyles), |
| | | f: common_vendor.n($data.popupstyle), |
| | | g: common_vendor.o((...args) => $options.clear && $options.clear(...args)), |
| | | h: common_vendor.o($options.onTap), |
| | | i: common_vendor.p({ |
| | | ["mode-class"]: $data.ani, |
| | | name: "content", |
| | | styles: $data.transClass, |
| | | duration: $data.duration, |
| | | show: $data.showTrans |
| | | }), |
| | | j: common_vendor.o((...args) => $options.touchstart && $options.touchstart(...args)), |
| | | k: common_vendor.n($data.popupstyle), |
| | | l: common_vendor.n($options.isDesktop ? "fixforpc-z-index" : "") |
| | | }) : {}); |
| | | } |
| | | const Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render]]); |
| | | wx.createComponent(Component); |
对比新文件 |
| | |
| | | { |
| | | "component": true, |
| | | "usingComponents": { |
| | | "uni-transition": "../uni-transition/uni-transition" |
| | | } |
| | | } |
对比新文件 |
| | |
| | | <view wx:if="{{a}}" class="{{['uni-popup', k, l]}}"><view bindtouchstart="{{j}}"><uni-transition wx:if="{{b}}" key="1" bindclick="{{c}}" u-i="8c28e6d6-0" bind:__l="__l" u-p="{{d}}"/><uni-transition wx:if="{{i}}" u-s="{{['d']}}" key="2" bindclick="{{h}}" u-i="8c28e6d6-1" bind:__l="__l" u-p="{{i}}"><view style="{{e}}" class="{{['uni-popup__wrapper', f]}}" bindtap="{{g}}"><slot/></view></uni-transition></view></view> |
对比新文件 |
| | |
| | | /** |
| | | * 这里是uni-app内置的常用样式变量 |
| | | * |
| | | * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量 |
| | | * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App |
| | | * |
| | | */ |
| | | /** |
| | | * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能 |
| | | * |
| | | * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件 |
| | | */ |
| | | /* 颜色变量 */ |
| | | /* 行为相关颜色 */ |
| | | /* 文字基本颜色 */ |
| | | /* 背景颜色 */ |
| | | /* 边框颜色 */ |
| | | /* 尺寸变量 */ |
| | | /* 文字尺寸 */ |
| | | /* 图片尺寸 */ |
| | | /* Border Radius */ |
| | | /* 水平间距 */ |
| | | /* 垂直间距 */ |
| | | /* 透明度 */ |
| | | /* 文章场景相关 */ |
| | | .uni-popup { |
| | | position: fixed; |
| | | z-index: 99; |
| | | } |
| | | .uni-popup.top, .uni-popup.left, .uni-popup.right { |
| | | top: 0; |
| | | } |
| | | .uni-popup .uni-popup__wrapper { |
| | | display: block; |
| | | position: relative; |
| | | /* iphonex 等安全区设置,底部安全区适配 */ |
| | | } |
| | | .uni-popup .uni-popup__wrapper.left, .uni-popup .uni-popup__wrapper.right { |
| | | padding-top: 0; |
| | | flex: 1; |
| | | } |
| | | .fixforpc-z-index { |
| | | z-index: 999; |
| | | } |
| | | .fixforpc-top { |
| | | top: 0; |
| | | } |
对比新文件 |
| | |
| | | "use strict"; |
| | | const common_vendor = require("../../../../../common/vendor.js"); |
| | | const _sfc_main = { |
| | | name: "uniTransition", |
| | | emits: ["click", "change"], |
| | | props: { |
| | | show: { |
| | | type: Boolean, |
| | | default: false |
| | | }, |
| | | modeClass: { |
| | | type: [Array, String], |
| | | default() { |
| | | return "fade"; |
| | | } |
| | | }, |
| | | duration: { |
| | | type: Number, |
| | | default: 300 |
| | | }, |
| | | styles: { |
| | | type: Object, |
| | | default() { |
| | | return {}; |
| | | } |
| | | }, |
| | | customClass: { |
| | | type: String, |
| | | default: "" |
| | | }, |
| | | onceRender: { |
| | | type: Boolean, |
| | | default: false |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | isShow: false, |
| | | transform: "", |
| | | opacity: 1, |
| | | animationData: {}, |
| | | durationTime: 300, |
| | | config: {} |
| | | }; |
| | | }, |
| | | watch: { |
| | | show: { |
| | | handler(newVal) { |
| | | if (newVal) { |
| | | this.open(); |
| | | } else { |
| | | if (this.isShow) { |
| | | this.close(); |
| | | } |
| | | } |
| | | }, |
| | | immediate: true |
| | | } |
| | | }, |
| | | computed: { |
| | | // 生成样式数据 |
| | | stylesObject() { |
| | | let styles = { |
| | | ...this.styles, |
| | | "transition-duration": this.duration / 1e3 + "s" |
| | | }; |
| | | let transform = ""; |
| | | for (let i in styles) { |
| | | let line = this.toLine(i); |
| | | transform += line + ":" + styles[i] + ";"; |
| | | } |
| | | return transform; |
| | | }, |
| | | // 初始化动画条件 |
| | | transformStyles() { |
| | | return "transform:" + this.transform + ";opacity:" + this.opacity + ";" + this.stylesObject; |
| | | } |
| | | }, |
| | | created() { |
| | | this.config = { |
| | | duration: this.duration, |
| | | timingFunction: "ease", |
| | | transformOrigin: "50% 50%", |
| | | delay: 0 |
| | | }; |
| | | this.durationTime = this.duration; |
| | | }, |
| | | methods: { |
| | | /** |
| | | * ref 触发 初始化动画 |
| | | */ |
| | | init(obj = {}) { |
| | | if (obj.duration) { |
| | | this.durationTime = obj.duration; |
| | | } |
| | | this.animation = common_vendor.createAnimation(Object.assign(this.config, obj), this); |
| | | }, |
| | | /** |
| | | * 点击组件触发回调 |
| | | */ |
| | | onClick() { |
| | | this.$emit("click", { |
| | | detail: this.isShow |
| | | }); |
| | | }, |
| | | /** |
| | | * ref 触发 动画分组 |
| | | * @param {Object} obj |
| | | */ |
| | | step(obj, config = {}) { |
| | | if (!this.animation) |
| | | return; |
| | | for (let i in obj) { |
| | | try { |
| | | if (typeof obj[i] === "object") { |
| | | this.animation[i](...obj[i]); |
| | | } else { |
| | | this.animation[i](obj[i]); |
| | | } |
| | | } catch (e) { |
| | | console.error(`方法 ${i} 不存在`); |
| | | } |
| | | } |
| | | this.animation.step(config); |
| | | return this; |
| | | }, |
| | | /** |
| | | * ref 触发 执行动画 |
| | | */ |
| | | run(fn) { |
| | | if (!this.animation) |
| | | return; |
| | | this.animation.run(fn); |
| | | }, |
| | | // 开始过度动画 |
| | | open() { |
| | | clearTimeout(this.timer); |
| | | this.transform = ""; |
| | | this.isShow = true; |
| | | let { opacity, transform } = this.styleInit(false); |
| | | if (typeof opacity !== "undefined") { |
| | | this.opacity = opacity; |
| | | } |
| | | this.transform = transform; |
| | | this.$nextTick(() => { |
| | | this.timer = setTimeout(() => { |
| | | this.animation = common_vendor.createAnimation(this.config, this); |
| | | this.tranfromInit(false).step(); |
| | | this.animation.run(); |
| | | this.$emit("change", { |
| | | detail: this.isShow |
| | | }); |
| | | }, 20); |
| | | }); |
| | | }, |
| | | // 关闭过度动画 |
| | | close(type) { |
| | | if (!this.animation) |
| | | return; |
| | | this.tranfromInit(true).step().run(() => { |
| | | this.isShow = false; |
| | | this.animationData = null; |
| | | this.animation = null; |
| | | let { opacity, transform } = this.styleInit(false); |
| | | this.opacity = opacity || 1; |
| | | this.transform = transform; |
| | | this.$emit("change", { |
| | | detail: this.isShow |
| | | }); |
| | | }); |
| | | }, |
| | | // 处理动画开始前的默认样式 |
| | | styleInit(type) { |
| | | let styles = { |
| | | transform: "" |
| | | }; |
| | | let buildStyle = (type2, mode) => { |
| | | if (mode === "fade") { |
| | | styles.opacity = this.animationType(type2)[mode]; |
| | | } else { |
| | | styles.transform += this.animationType(type2)[mode] + " "; |
| | | } |
| | | }; |
| | | if (typeof this.modeClass === "string") { |
| | | buildStyle(type, this.modeClass); |
| | | } else { |
| | | this.modeClass.forEach((mode) => { |
| | | buildStyle(type, mode); |
| | | }); |
| | | } |
| | | return styles; |
| | | }, |
| | | // 处理内置组合动画 |
| | | tranfromInit(type) { |
| | | let buildTranfrom = (type2, mode) => { |
| | | let aniNum = null; |
| | | if (mode === "fade") { |
| | | aniNum = type2 ? 0 : 1; |
| | | } else { |
| | | aniNum = type2 ? "-100%" : "0"; |
| | | if (mode === "zoom-in") { |
| | | aniNum = type2 ? 0.8 : 1; |
| | | } |
| | | if (mode === "zoom-out") { |
| | | aniNum = type2 ? 1.2 : 1; |
| | | } |
| | | if (mode === "slide-right") { |
| | | aniNum = type2 ? "100%" : "0"; |
| | | } |
| | | if (mode === "slide-bottom") { |
| | | aniNum = type2 ? "100%" : "0"; |
| | | } |
| | | } |
| | | this.animation[this.animationMode()[mode]](aniNum); |
| | | }; |
| | | if (typeof this.modeClass === "string") { |
| | | buildTranfrom(type, this.modeClass); |
| | | } else { |
| | | this.modeClass.forEach((mode) => { |
| | | buildTranfrom(type, mode); |
| | | }); |
| | | } |
| | | return this.animation; |
| | | }, |
| | | animationType(type) { |
| | | return { |
| | | fade: type ? 0 : 1, |
| | | "slide-top": `translateY(${type ? "0" : "-100%"})`, |
| | | "slide-right": `translateX(${type ? "0" : "100%"})`, |
| | | "slide-bottom": `translateY(${type ? "0" : "100%"})`, |
| | | "slide-left": `translateX(${type ? "0" : "-100%"})`, |
| | | "zoom-in": `scaleX(${type ? 1 : 0.8}) scaleY(${type ? 1 : 0.8})`, |
| | | "zoom-out": `scaleX(${type ? 1 : 1.2}) scaleY(${type ? 1 : 1.2})` |
| | | }; |
| | | }, |
| | | // 内置动画类型与实际动画对应字典 |
| | | animationMode() { |
| | | return { |
| | | fade: "opacity", |
| | | "slide-top": "translateY", |
| | | "slide-right": "translateX", |
| | | "slide-bottom": "translateY", |
| | | "slide-left": "translateX", |
| | | "zoom-in": "scale", |
| | | "zoom-out": "scale" |
| | | }; |
| | | }, |
| | | // 驼峰转中横线 |
| | | toLine(name) { |
| | | return name.replace(/([A-Z])/g, "-$1").toLowerCase(); |
| | | } |
| | | } |
| | | }; |
| | | function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { |
| | | return { |
| | | a: $data.isShow, |
| | | b: $data.animationData, |
| | | c: common_vendor.n($props.customClass), |
| | | d: common_vendor.s($options.transformStyles), |
| | | e: common_vendor.o((...args) => $options.onClick && $options.onClick(...args)) |
| | | }; |
| | | } |
| | | const Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render]]); |
| | | wx.createComponent(Component); |
对比新文件 |
| | |
| | | { |
| | | "component": true, |
| | | "usingComponents": {} |
| | | } |
对比新文件 |
| | |
| | | <view hidden="{{!a}}" ref="ani" animation="{{b}}" class="{{c}}" style="{{d}}" bindtap="{{e}}"><slot></slot></view> |
对比新文件 |
| | |
| | | "use strict"; |
| | | const common_vendor = require("../../common/vendor.js"); |
| | | const _sfc_main = { |
| | | __name: "index", |
| | | setup(__props) { |
| | | const back = () => { |
| | | common_vendor.index.navigateTo({ |
| | | url: "/pages/login/index" |
| | | }); |
| | | }; |
| | | const capsuleHeight = common_vendor.ref(0); |
| | | common_vendor.onMounted(() => { |
| | | if (common_vendor.index.getMenuButtonBoundingClientRect) { |
| | | capsuleHeight.value = (common_vendor.index.getMenuButtonBoundingClientRect().top + common_vendor.index.getMenuButtonBoundingClientRect().height) * 2; |
| | | } |
| | | }); |
| | | const functionList = common_vendor.ref([ |
| | | { text: "余额", icon: "../../static/images/index/icon31.png", url: "/pages/login/index" }, |
| | | { text: "余额", icon: "../../static/images/index/icon32.png", url: "/pages/login/index" }, |
| | | { text: "余额", icon: "../../static/images/index/icon33.png", url: "/pages/login/index" }, |
| | | { text: "余额", icon: "../../static/images/index/icon34.png", url: "/pages/login/index" }, |
| | | { text: "余额", icon: "../../static/images/index/icon35.png", url: "/pages/login/index" }, |
| | | { text: "余额", icon: "../../static/images/index/icon36.png", url: "/pages/login/index" }, |
| | | { text: "余额", icon: "../../static/images/index/icon37.png", url: "/pages/login/index" }, |
| | | { text: "余额", icon: "../../static/images/index/icon38.png", url: "/pages/login/index" } |
| | | ]); |
| | | return (_ctx, _cache) => { |
| | | return { |
| | | a: capsuleHeight.value + "rpx", |
| | | b: common_vendor.f(functionList.value, (item, index, i0) => { |
| | | return { |
| | | a: item.icon, |
| | | b: common_vendor.t(item.text), |
| | | c: common_vendor.o(($event) => _ctx.navTo(item.url), index), |
| | | d: index |
| | | }; |
| | | }), |
| | | c: common_vendor.o(($event) => back()) |
| | | }; |
| | | }; |
| | | } |
| | | }; |
| | | const MiniProgramPage = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__scopeId", "data-v-1cf27b2a"]]); |
| | | wx.createPage(MiniProgramPage); |
对比新文件 |
| | |
| | | { |
| | | "navigationStyle": "custom", |
| | | "usingComponents": {} |
| | | } |
对比新文件 |
| | |
| | | <view class="container data-v-1cf27b2a"><view class="content data-v-1cf27b2a"><view class="card-box data-v-1cf27b2a" style="{{'padding-top:' + a}}"><view class="card data-v-1cf27b2a"></view></view><view class="function-box1 data-v-1cf27b2a"><view class="box1-bg data-v-1cf27b2a"></view><view class="box1-bg data-v-1cf27b2a"></view><view class="box1-bg data-v-1cf27b2a"></view></view><view class="function-box2 data-v-1cf27b2a"><view class="box2-title data-v-1cf27b2a"><text class="data-v-1cf27b2a">功能列表</text></view><view class="box2-content data-v-1cf27b2a"><block wx:for="{{b}}" wx:for-item="item" wx:key="d"><view class="box2-item data-v-1cf27b2a" bindtap="{{item.c}}"><image class="data-v-1cf27b2a" src="{{item.a}}" alt=""></image><view class="box2-item-text data-v-1cf27b2a">{{item.b}}</view></view></block></view></view></view><button class="data-v-1cf27b2a" bindtap="{{c}}"></button></view> |
对比新文件 |
| | |
| | | /** |
| | | * 这里是uni-app内置的常用样式变量 |
| | | * |
| | | * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量 |
| | | * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App |
| | | * |
| | | */ |
| | | /** |
| | | * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能 |
| | | * |
| | | * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件 |
| | | */ |
| | | /* 颜色变量 */ |
| | | /* 行为相关颜色 */ |
| | | /* 文字基本颜色 */ |
| | | /* 背景颜色 */ |
| | | /* 边框颜色 */ |
| | | /* 尺寸变量 */ |
| | | /* 文字尺寸 */ |
| | | /* 图片尺寸 */ |
| | | /* Border Radius */ |
| | | /* 水平间距 */ |
| | | /* 垂直间距 */ |
| | | /* 透明度 */ |
| | | /* 文章场景相关 */ |
| | | .container.data-v-1cf27b2a { |
| | | width: 100%; |
| | | height: 100vh; |
| | | overflow: scroll; |
| | | } |
| | | .container .content.data-v-1cf27b2a { |
| | | width: 100%; |
| | | height: 100vh; |
| | | background: #F6F6F6; |
| | | } |
| | | .card-box.data-v-1cf27b2a { |
| | | width: 100%; |
| | | height: auto; |
| | | box-sizing: border-box; |
| | | padding: 0 32rpx; |
| | | background: linear-gradient(to bottom, #5EA1FA, #D2F2FE); |
| | | } |
| | | .card-box .card.data-v-1cf27b2a { |
| | | width: 100%; |
| | | height: 304rpx; |
| | | background-image: url(""); |
| | | background-repeat: no-repeat; |
| | | background-size: 100%; |
| | | } |
| | | .function-box1.data-v-1cf27b2a { |
| | | width: 100%; |
| | | box-sizing: border-box; |
| | | height: 264rpx; |
| | | padding: 32rpx; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | } |
| | | .function-box1 .box1-bg.data-v-1cf27b2a { |
| | | width: 212rpx; |
| | | height: 200rpx; |
| | | border-radius: 24rpx; |
| | | background: #fff; |
| | | box-shadow: 0 0 12rpx 2rpx rgba(13, 118, 255, 0.16); |
| | | } |
| | | .function-box2.data-v-1cf27b2a { |
| | | width: 100%; |
| | | box-sizing: border-box; |
| | | height: 460rpx; |
| | | padding: 0 32rpx 32rpx; |
| | | } |
| | | .function-box2 .box2-title.data-v-1cf27b2a { |
| | | width: 100%; |
| | | font-weight: 300; |
| | | font-size: 32rpx; |
| | | color: #000000; |
| | | text-align: left; |
| | | margin-bottom: 10rpx; |
| | | margin-left: 30rpx; |
| | | } |
| | | .function-box2 .box2-content.data-v-1cf27b2a { |
| | | box-sizing: border-box; |
| | | padding: 30rpx 50rpx; |
| | | width: 686rpx; |
| | | height: 374rpx; |
| | | background: #fff; |
| | | border-radius: 24rpx; |
| | | box-shadow: 0 0 12rpx 2rpx rgba(0, 0, 0, 0.1); |
| | | display: flex; |
| | | flex-wrap: wrap; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | } |
| | | .function-box2 .box2-content .box2-item.data-v-1cf27b2a { |
| | | width: 120rpx; |
| | | height: 130rpx; |
| | | } |
| | | .function-box2 .box2-content .box2-item image.data-v-1cf27b2a { |
| | | width: 90rpx; |
| | | height: 90rpx; |
| | | margin: 0 auto; |
| | | } |
| | | .function-box2 .box2-content .box2-item .box2-item-text.data-v-1cf27b2a { |
| | | width: 100%; |
| | | height: 40rpx; |
| | | font-weight: 300; |
| | | font-size: 28rpx; |
| | | color: #000000; |
| | | text-align: center; |
| | | } |
| | | button.data-v-1cf27b2a { |
| | | width: 100rpx; |
| | | height: 50rpx; |
| | | } |
对比新文件 |
| | |
| | | "use strict"; |
| | | const common_vendor = require("../../common/vendor.js"); |
| | | const common_assets = require("../../common/assets.js"); |
| | | if (!Array) { |
| | | const _easycom_uni_popup2 = common_vendor.resolveComponent("uni-popup"); |
| | | _easycom_uni_popup2(); |
| | | } |
| | | const _easycom_uni_popup = () => "../../node-modules/@dcloudio/uni-ui/lib/uni-popup/uni-popup.js"; |
| | | if (!Math) { |
| | | _easycom_uni_popup(); |
| | | } |
| | | const _sfc_main = { |
| | | __name: "index", |
| | | setup(__props) { |
| | | let popupRef = common_vendor.ref(null); |
| | | const login = () => { |
| | | common_vendor.index.navigateTo({ |
| | | url: "/pages/index/index" |
| | | }); |
| | | console.log("login1"); |
| | | }; |
| | | const wxLoginPopup = () => { |
| | | popupRef.value.open("bottom"); |
| | | }; |
| | | const wxLoginFn = () => { |
| | | console.log("login2"); |
| | | popupRef.value.close("bottom"); |
| | | }; |
| | | return (_ctx, _cache) => { |
| | | return { |
| | | a: common_vendor.o(($event) => login()), |
| | | b: common_assets._imports_0, |
| | | c: common_vendor.o(($event) => wxLoginPopup()), |
| | | d: common_assets._imports_1, |
| | | e: common_vendor.o(($event) => common_vendor.unref(popupRef).close("bottom")), |
| | | f: common_vendor.o(($event) => wxLoginFn()), |
| | | g: common_vendor.sr(popupRef, "169f96b2-0", { |
| | | "k": "popupRef" |
| | | }), |
| | | h: common_vendor.p({ |
| | | ["background-color"]: "#fff" |
| | | }) |
| | | }; |
| | | }; |
| | | } |
| | | }; |
| | | wx.createPage(_sfc_main); |
对比新文件 |
| | |
| | | { |
| | | "navigationStyle": "custom", |
| | | "usingComponents": { |
| | | "uni-popup": "../../node-modules/@dcloudio/uni-ui/lib/uni-popup/uni-popup" |
| | | } |
| | | } |
对比新文件 |
| | |
| | | <view class="container"><view class="content"><view class="title"><view class="text1">欢迎登录</view><view class="text2">Welcome to login</view></view><view class="form"><view class="form-input"><input type="text" placeholder="输入账号"></input></view><view class="form-input"><input password type="text" placeholder="输入密码"></input></view></view><view class="login-btn"><button bindtap="{{a}}">登录</button></view><view class="bottom"><view class="divide"><view class="line"></view><view class="divide-text">第三方账号登录</view><view class="line"></view></view><view class="other-login"><image src="{{b}}" alt="" bindtap="{{c}}"/></view></view></view><uni-popup wx:if="{{h}}" class="r" u-s="{{['d']}}" u-r="popupRef" u-i="169f96b2-0" bind:__l="__l" u-p="{{h}}"><view class="popup-content"><text class="popup-title">微信登录</text><view class="hr"></view><view class="img-box"><image src="{{d}}" alt="" class="img"/></view><view class="info-box"><view class="info-text1">青源直饮水平台申请获取以下权限:</view><view class="hr2"></view><view class="info-text2">· 获得你的公开信息(昵称、头像、地区及性别)</view><view class="button-box"><button class="button1" bindtap="{{e}}">取消</button><button class="button2" bindtap="{{f}}">确定</button></view></view></view></uni-popup></view> |
对比新文件 |
| | |
| | | /** |
| | | * 这里是uni-app内置的常用样式变量 |
| | | * |
| | | * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量 |
| | | * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App |
| | | * |
| | | */ |
| | | /** |
| | | * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能 |
| | | * |
| | | * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件 |
| | | */ |
| | | /* 颜色变量 */ |
| | | /* 行为相关颜色 */ |
| | | /* 文字基本颜色 */ |
| | | /* 背景颜色 */ |
| | | /* 边框颜色 */ |
| | | /* 尺寸变量 */ |
| | | /* 文字尺寸 */ |
| | | /* 图片尺寸 */ |
| | | /* Border Radius */ |
| | | /* 水平间距 */ |
| | | /* 垂直间距 */ |
| | | /* 透明度 */ |
| | | /* 文章场景相关 */ |
| | | page { |
| | | width: 100%; |
| | | height: 100%; |
| | | } |
| | | .container { |
| | | width: 100%; |
| | | height: 100%; |
| | | background-image: url("../../static/images/login/bg2.png"); |
| | | background-size: 100%; |
| | | background-repeat: no-repeat; |
| | | position: relative; |
| | | } |
| | | .container .content { |
| | | position: absolute; |
| | | width: 680rpx; |
| | | height: 1080rpx; |
| | | top: 22%; |
| | | left: calc(50% - 340rpx); |
| | | background-image: url(""); |
| | | background-repeat: no-repeat; |
| | | background-size: 100%; |
| | | } |
| | | .container .content .title { |
| | | width: 100%; |
| | | height: 180rpx; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: flex-start; |
| | | padding: 9% 0 0 13%; |
| | | box-sizing: border-box; |
| | | } |
| | | .container .content .title .text1 { |
| | | width: 250rpx; |
| | | font-weight: 500; |
| | | font-size: 56rpx; |
| | | color: #345DB1; |
| | | text-align: left; |
| | | margin-left: 14rpx; |
| | | margin-bottom: 20rpx; |
| | | } |
| | | .container .content .title .text2 { |
| | | width: 500rpx; |
| | | font-weight: 400; |
| | | font-size: 36rpx; |
| | | color: #9AB6DD; |
| | | text-align: left; |
| | | } |
| | | .container .content .form { |
| | | width: 100%; |
| | | height: 260rpx; |
| | | margin-top: 125rpx; |
| | | /* background-color: #345DB1; */ |
| | | box-sizing: border-box; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: space-between; |
| | | } |
| | | .container .content .form .form-input { |
| | | width: 582rpx; |
| | | height: 100rpx; |
| | | background-image: url(""); |
| | | background-repeat: no-repeat; |
| | | background-size: 100%; |
| | | background-position: center; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: flex-start; |
| | | margin: 0 auto; |
| | | } |
| | | .container .content .form .form-input .uni-input-placeholder { |
| | | color: #9DC4E8; |
| | | } |
| | | .container .content .form .form-input input { |
| | | width: 80%; |
| | | margin-left: 60rpx; |
| | | font-weight: 400; |
| | | font-size: 32rpx; |
| | | text-align: left; |
| | | color: #2b4e82; |
| | | } |
| | | .container .content .login-btn { |
| | | width: 530rpx; |
| | | height: 100rpx; |
| | | margin: 80rpx auto 60rpx; |
| | | } |
| | | .container .content .login-btn button { |
| | | background: linear-gradient(to right, #51C9F6, #4E9BFF); |
| | | font-weight: 500; |
| | | font-size: 36rpx; |
| | | color: #FFFFFF; |
| | | border-radius: 20rpx; |
| | | } |
| | | .container .content .bottom { |
| | | width: 100%; |
| | | height: 180rpx; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | } |
| | | .container .content .bottom .divide { |
| | | box-sizing: border-box; |
| | | width: 100%; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | padding: 0 85rpx; |
| | | /* background: #446f52; */ |
| | | } |
| | | .container .content .bottom .divide .line { |
| | | width: 125rpx; |
| | | height: 2rpx; |
| | | background: #959595; |
| | | } |
| | | .container .content .bottom .divide .divide-text { |
| | | font-weight: 600; |
| | | font-size: 28rpx; |
| | | color: #B9B9B9; |
| | | text-align: center; |
| | | } |
| | | .container .content .bottom .other-login { |
| | | box-sizing: border-box; |
| | | width: 100%; |
| | | height: 100rpx; |
| | | /* background: #5d7682; */ |
| | | padding: 0 90rpx; |
| | | display: flex; |
| | | justify-content: center; |
| | | align-items: center; |
| | | } |
| | | .container .content .bottom .other-login img { |
| | | width: 76rpx; |
| | | height: 76rpx; |
| | | /* background: #345DB1; */ |
| | | } |
| | | .container .popup-content { |
| | | height: 560rpx; |
| | | position: relative; |
| | | z-index: 1000; |
| | | } |
| | | .container .popup-content .popup-title { |
| | | width: 100%; |
| | | display: block; |
| | | text-align: center; |
| | | margin: 15rpx 0; |
| | | font-weight: 600; |
| | | font-size: 36rpx; |
| | | } |
| | | .container .popup-content .hr { |
| | | width: 100%; |
| | | height: 2rpx; |
| | | background: #e2e2e2; |
| | | } |
| | | .container .popup-content .img-box { |
| | | width: 65rpx; |
| | | height: 65rpx; |
| | | margin: 40rpx auto 30rpx; |
| | | border: 1rpx solid #e2e2e2; |
| | | border-radius: 50%; |
| | | padding: 15rpx; |
| | | } |
| | | .container .popup-content .img-box .img { |
| | | width: 100%; |
| | | height: 100%; |
| | | } |
| | | .container .popup-content .info-box { |
| | | width: 100%; |
| | | padding: 0 80rpx; |
| | | box-sizing: border-box; |
| | | } |
| | | .container .popup-content .info-box .hr2 { |
| | | width: 100%; |
| | | height: 2rpx; |
| | | background: #e2e2e2; |
| | | margin: 20rpx 0; |
| | | } |
| | | .container .popup-content .info-box .info-text2 { |
| | | font-size: 26rpx; |
| | | color: #767676; |
| | | } |
| | | .container .popup-content .button-box { |
| | | display: flex; |
| | | margin-top: 20rpx; |
| | | } |
| | | .container .popup-content .button-box button { |
| | | width: 230rpx; |
| | | height: 80rpx; |
| | | line-height: 80rpx; |
| | | border: none; |
| | | box-shadow: none; |
| | | margin-top: 30rpx; |
| | | } |
| | | .container .popup-content .button-box button::after { |
| | | border: none !important; |
| | | } |
| | | .container .popup-content .button-box .button1 { |
| | | background-color: #F0F0F0; |
| | | color: #333333; |
| | | } |
| | | .container .popup-content .button-box .button2 { |
| | | background-color: #06BF5E; |
| | | color: #ffffff; |
| | | } |
对比新文件 |
| | |
| | | { |
| | | "description": "项目配置文件。", |
| | | "packOptions": { |
| | | "ignore": [], |
| | | "include": [] |
| | | }, |
| | | "setting": { |
| | | "urlCheck": false, |
| | | "es6": true, |
| | | "postcss": false, |
| | | "minified": false, |
| | | "newFeature": true, |
| | | "bigPackageSizeSupport": true, |
| | | "babelSetting": { |
| | | "ignore": [], |
| | | "disablePlugins": [], |
| | | "outputPath": "" |
| | | } |
| | | }, |
| | | "compileType": "miniprogram", |
| | | "libVersion": "3.3.5", |
| | | "appid": "touristappid", |
| | | "projectname": "water-drinking-uniapp", |
| | | "condition": {}, |
| | | "editorSetting": { |
| | | "tabIndent": "insertSpaces", |
| | | "tabSize": 2 |
| | | } |
| | | } |
对比新文件 |
| | |
| | | { |
| | | "description": "项目私有配置文件。此文件中的内容将覆盖 project.config.json 中的相同字段。项目的改动优先同步到此文件中。详见文档:https://developers.weixin.qq.com/miniprogram/dev/devtools/projectconfig.html", |
| | | "projectname": "water-drinking-uniapp", |
| | | "setting": { |
| | | "compileHotReLoad": true |
| | | } |
| | | } |