【uniapp】小程序自定义一个通用的返回按钮组件

左边箭头,右边文字可以自定义,但是不要太长,太长可以自己改 .back的width值,改宽一点。

用这个组件的时候首先要在pages.json里把导航栏变成自定义的:

javascript 复制代码
  
  
  
   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        ,{
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                   
        
        "path" : 
        
        "pages/test/test",
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                   
        
        "style" :                                                                                    
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
                    {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                       
        
        "navigationBarTitleText": 
        
        "",
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                       
        
        "enablePullDownRefresh": 
        
        false
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
                    }
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                   
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
                }
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
                ,{
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                   
        
        "path" : 
        
        "pages/shop/shop",
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                   
        
        "style" :                                                                                    
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
                    {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                       
        
        "navigationBarTitleText": 
        
        "",
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                       
        
        "enablePullDownRefresh": 
        
        false,
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
                       
        
        //这个-->自定义导航栏
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        "navigationStyle": 
        
        "custom"
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
                    }
       
       
       
      
      
      

  

  
  
  
   
   ![](https://file.jishuzhan.net/article/1763804089101062146/e131387152448193c676d6f7de678c8e.webp)
  
  
  
  
  
  

组件:backPages.vue

javascript 复制代码
  
  
  
   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        <template>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        <view class="big_out">
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        <!-- 左上角返回按钮 -->
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        <!-- 这里为什么要加4px,是因为这个左箭头<的高度为16rpx需要下降一半,就是8rpx=4px,可以自己试一下,我这里没有问题 -->
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        <view class="back"  :style="'margin-top:'+ (titletop+4)+'px'"  @click="back_page"> 
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        <view class="back_img">
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        </view>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        <view class="back_text">
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        <slot>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        					{{backtext}}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        </slot>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        </view>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        </view>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        </view>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        </template>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        <script>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        export 
        
        default {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        name: 
        
        "backPages",
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        props: {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        backtext: 
        
        String,
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		},
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        data(
        
        ) {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        return {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        titleheight: 
        
        0,
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        titletop: 
        
        0
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        			};
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		},
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
               
        
        //这里原来使用的onLoad一直有bug(不重新进入页面就会错位),
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
               
        
        // 后来使用onShow  更改于2022/09/30  以后再修改
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        onShow(
        
        ) {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        //加载时调用 getHeight
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        this.
        
        getHeight();
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		},
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        methods: {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        //利用胶囊按钮定位宽高
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        getHeight(
        
        ) {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        let res = uni.
        
        getMenuButtonBoundingClientRect();
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        this.
        
        titletop = res.
        
        top;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
        
        this.
        
        titleheight = res.
        
        height
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        			},
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        //直接返回上一级
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        back_page(
        
        ) {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        				uni.
        
        navigateBack({
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       					
        
        delta: 
        
        1 
        
        // 返回的页面数
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        				})
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        			},
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        	}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        </script>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        <style scoped>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        .big_out {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        position: fixed;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	    
        
        z-index: 
        
        999;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        /* background-color: red; */
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        	}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        .back {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        position: absolute;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        height: 
        
        50rpx;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        width: 
        
        120rpx;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        	}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        .back_img {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        /* 用border值来控制箭头粗细 */
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        border: 
        
        3px solid black;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        /* 上、右、下、左  四个边框的宽度 */
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        border-width: 
        
        0px 
        
        2px 
        
        2px 
        
        0px;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        display: inline-block;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        /* padding值控制箭头大小 */
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        padding: 
        
        5px;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        transform: 
        
        rotate(
        
        135deg);
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		-webkit-
        
        transform: 
        
        rotate(
        
        135deg);
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        margin-left: 
        
        30rpx;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        	}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        .back_text {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        float: right;
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        	}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        </style>
       
       
       
      
      
      

  

  
  
  
   
   ![](https://file.jishuzhan.net/article/1763804089101062146/e131387152448193c676d6f7de678c8e.webp)
  
  
  
  
  
  

使用的时候需要传按钮名:backtext = '返回或者自定义'

需要import引入组件并注册components才行,示例代码:

javascript 复制代码
  
  
  
   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        <template>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        <view>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        <backPages backtext='返回' >
        
        </backPages>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        </view>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        </template>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        <script>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        import backPages 
        
        from 
        
        "@/components/backPages.vue"
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       	
        
        export 
        
        default {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        components:{
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        			backPages
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		},
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        data(
        
        ) {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
        
        return {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       				
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        			}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		},
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       		
        
        methods: {
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       			
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        		}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        	}
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        </script>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        <style>
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
        
       
       
       
      
      
      

   
* 
      
      
      
       
       
       
      
      
      

      
      
      

       
       
       
        
        </style>
       
       
       
      
      
      

  

  
  
  
   
   ![](https://file.jishuzhan.net/article/1763804089101062146/e131387152448193c676d6f7de678c8e.webp)
  
  
  
  
  
  

组件默认回到上一层级,自定义请更改组价的back_page方法。

转:https://blog.csdn.net/ONLYSRY/article/details/126178045

相关推荐
小徐_23331 天前
uni-app vue3 也能使用 Echarts?Wot Starter 是这样做的!
前端·uni-app·echarts
iOS阿玮1 天前
永远不要站在用户的对立面,挑战大众的公知。
uni-app·app·apple
xw51 天前
uni-app中v-if使用”异常”
前端·uni-app
!win !1 天前
uni-app中v-if使用”异常”
前端·uni-app
2501_915918411 天前
iOS 上架全流程指南 iOS 应用发布步骤、App Store 上架流程、uni-app 打包上传 ipa 与审核实战经验分享
android·ios·小程序·uni-app·cocoa·iphone·webview
00后程序员张2 天前
iOS App 混淆与加固对比 源码混淆与ipa文件混淆的区别、iOS代码保护与应用安全场景最佳实践
android·安全·ios·小程序·uni-app·iphone·webview
少年阿闯~~2 天前
CSS3的新特性
前端·javascript·css3
破无差2 天前
《赛事报名系统小程序》
小程序·html·uniapp
00后程序员张2 天前
详细解析苹果iOS应用上架到App Store的完整步骤与指南
android·ios·小程序·https·uni-app·iphone·webview
海绵宝宝不喜欢侬2 天前
uniapp-微信小程序分享功能-onShareAppMessage
微信小程序·小程序·uni-app