app-layout.vue 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <template>
  2. <view class="app-layout">
  3. <scroll-view scroll-y="true" class="scroll-view">
  4. <slot></slot>
  5. </scroll-view>
  6. </view>
  7. </template>
  8. <script>
  9. export default {
  10. name: "app-layout",
  11. data() {
  12. return {}
  13. },
  14. methods: {
  15. login(){
  16. uni.login({
  17. provider: 'weixin',
  18. success: res => {
  19. console.log('-->data',res)
  20. uni.getUserInfo({
  21. provider: 'weixin',
  22. success: data => {
  23. let params = {
  24. code: res.code,
  25. encryptedData: data.encryptedData,
  26. iv:data.iv,
  27. signature:data.signature
  28. }
  29. this.$u.api.login(params).then(loginRes => {
  30. this.$u.vuex(this.$const.USER_TOKEN,loginRes.token)
  31. this.$u.vuex(this.$const.USER_DATA,loginRes.user)
  32. })
  33. }
  34. });
  35. }
  36. });
  37. }
  38. },
  39. created(){
  40. if(!this.vuex_user_token){
  41. this.login()
  42. }
  43. }
  44. }
  45. </script>
  46. <style lang="scss" scoped>
  47. .app-layout{
  48. .scroll-view{
  49. padding-bottom: calc(var(--window-bottom) + 20px);
  50. /*height: calc(100vh - var(--window-top));*/
  51. width: 100%;
  52. overflow: hidden;
  53. }
  54. }
  55. </style>