index.vue 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. <template>
  2. <view class="shortcut" :style="{'--right': `${rightPx}px`, '--bottom': `${bottomPx}px`}">
  3. <!-- 首页 -->
  4. <view class="nav-item" :class="[isShow ? 'show_80' : transparent ? '' : 'hide_80']" @click="onTargetPage(0)">
  5. <text class="iconfont icon-home"></text>
  6. </view>
  7. <!-- 分类页 -->
  8. <!-- <view class="nav-item" :class="[isShow ? 'show_60' : (transparent ? '' : 'hide_60')]" @click="onTargetPage(1)">
  9. <text class="iconfont icon-cate"></text>
  10. </view> -->
  11. <!-- 购物车 -->
  12. <!-- <view class="nav-item" :class="[isShow ? 'show_40' : (transparent ? '' : 'hide_40')]" @click="onTargetPage(2)">
  13. <text class="iconfont icon-cart"></text>
  14. </view> -->
  15. <!-- 个人中心 -->
  16. <view class="nav-item" :class="[isShow ? 'show_20' : transparent ? '' : 'hide_20']" @click="onTargetPage(3)">
  17. <text class="iconfont icon-profile"></text>
  18. </view>
  19. <!-- 显示隐藏开关 -->
  20. <view class="nav-item nav-item__switch" :class="{shortcut_click_show: isShow}" @click="onToggleShow()">
  21. <text class="iconfont icon-daohang"></text>
  22. </view>
  23. </view>
  24. </template>
  25. <script>
  26. import {getTabBarLinks} from '@/core/app'
  27. export default {
  28. /**
  29. * 组件的属性列表
  30. * 用于组件自定义设置
  31. */
  32. props: {
  33. right: {
  34. type: Number,
  35. default: 30
  36. },
  37. bottom: {
  38. type: Number,
  39. default: 100
  40. }
  41. },
  42. data() {
  43. return {
  44. // 弹窗显示控制
  45. isShow: false,
  46. transparent: true
  47. }
  48. },
  49. computed: {
  50. rightPx() {
  51. return uni.upx2px(this.right)
  52. },
  53. bottomPx() {
  54. return uni.upx2px(this.bottom)
  55. }
  56. },
  57. methods: {
  58. /**
  59. * 导航菜单切换事件
  60. */
  61. onToggleShow() {
  62. const app = this
  63. app.isShow = !app.isShow
  64. app.transparent = false
  65. },
  66. /**
  67. * 导航页面跳转
  68. */
  69. onTargetPage(index = 0) {
  70. const tabLinks = getTabBarLinks()
  71. this.$navTo(tabLinks[index])
  72. }
  73. }
  74. }
  75. </script>
  76. <style lang="scss" scoped>
  77. /* 快捷导航 */
  78. .shortcut {
  79. position: fixed;
  80. right: calc(var(--window-right) + var(--right));
  81. bottom: calc(var(--window-bottom) + var(--bottom));
  82. width: 76rpx;
  83. height: 76rpx;
  84. line-height: 1;
  85. z-index: 5;
  86. border-radius: 50%;
  87. }
  88. /* 导航菜单元素 */
  89. .nav-item {
  90. position: absolute;
  91. bottom: 0;
  92. padding: 0;
  93. width: 76rpx;
  94. height: 76rpx;
  95. color: #fff;
  96. background: rgba(0, 0, 0, 0.4);
  97. border-radius: 50%;
  98. transform: rotate(0deg);
  99. opacity: 0;
  100. display: flex;
  101. justify-content: center;
  102. align-items: center;
  103. }
  104. .nav-item .iconfont {
  105. font-size: 40rpx;
  106. }
  107. /* 导航开关 */
  108. .nav-item__switch {
  109. opacity: 1;
  110. }
  111. .shortcut_click_show {
  112. margin-bottom: 0;
  113. background: #ff5454;
  114. }
  115. /* 显示动画 */
  116. .show_80 {
  117. bottom: 384rpx;
  118. animation: show_80 0.3s forwards;
  119. }
  120. .show_60 {
  121. bottom: 288rpx;
  122. animation: show_60 0.3s forwards;
  123. }
  124. .show_40 {
  125. bottom: 192rpx;
  126. animation: show_40 0.3s forwards;
  127. }
  128. .show_20 {
  129. bottom: 96rpx;
  130. animation: show_20 0.3s forwards;
  131. }
  132. @keyframes show_20 {
  133. from {
  134. bottom: 0;
  135. transform: rotate(0deg);
  136. opacity: 0;
  137. }
  138. to {
  139. bottom: 96rpx;
  140. transform: rotate(360deg);
  141. opacity: 1;
  142. }
  143. }
  144. @keyframes show_40 {
  145. from {
  146. bottom: 0;
  147. transform: rotate(0deg);
  148. opacity: 0;
  149. }
  150. to {
  151. bottom: 192rpx;
  152. transform: rotate(360deg);
  153. opacity: 1;
  154. }
  155. }
  156. @keyframes show_60 {
  157. from {
  158. bottom: 0;
  159. transform: rotate(0deg);
  160. opacity: 0;
  161. }
  162. to {
  163. bottom: 288rpx;
  164. transform: rotate(360deg);
  165. opacity: 1;
  166. }
  167. }
  168. @keyframes show_80 {
  169. from {
  170. bottom: 0;
  171. transform: rotate(0deg);
  172. opacity: 0;
  173. }
  174. to {
  175. bottom: 384rpx;
  176. transform: rotate(360deg);
  177. opacity: 1;
  178. }
  179. }
  180. /* 隐藏动画 */
  181. .hide_80 {
  182. bottom: 0;
  183. animation: hide_80 0.3s;
  184. opacity: 0;
  185. }
  186. .hide_60 {
  187. bottom: 0;
  188. animation: hide_60 0.3s;
  189. opacity: 0;
  190. }
  191. .hide_40 {
  192. bottom: 0;
  193. animation: hide_40 0.3s;
  194. opacity: 0;
  195. }
  196. .hide_20 {
  197. bottom: 0;
  198. animation: hide_20 0.3s;
  199. opacity: 0;
  200. }
  201. @keyframes hide_20 {
  202. from {
  203. bottom: 96rpx;
  204. transform: rotate(360deg);
  205. opacity: 1;
  206. }
  207. to {
  208. bottom: 0;
  209. transform: rotate(0deg);
  210. opacity: 0;
  211. }
  212. }
  213. @keyframes hide_40 {
  214. from {
  215. bottom: 192rpx;
  216. transform: rotate(360deg);
  217. opacity: 1;
  218. }
  219. to {
  220. bottom: 0;
  221. transform: rotate(0deg);
  222. opacity: 0;
  223. }
  224. }
  225. @keyframes hide_60 {
  226. from {
  227. bottom: 288rpx;
  228. transform: rotate(360deg);
  229. opacity: 1;
  230. }
  231. to {
  232. bottom: 0;
  233. transform: rotate(0deg);
  234. opacity: 0;
  235. }
  236. }
  237. @keyframes hide_80 {
  238. from {
  239. bottom: 384rpx;
  240. transform: rotate(360deg);
  241. opacity: 1;
  242. }
  243. to {
  244. bottom: 0;
  245. transform: rotate(0deg);
  246. opacity: 0;
  247. }
  248. }
  249. </style>