【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

相关推荐
getyefang7 小时前
uniapp如何接入星火大模型
ai·uni-app
@PHARAOH7 小时前
WHAT - uni-app 条件编译技术
小程序·uni-app·条件编译
hunzi_19 小时前
选择网上购物系统要看几方面?
java·微信小程序·小程序·uni-app·php
芭拉拉小魔仙12 小时前
Uniapp Vue3 小程序接入实时音视频TUICallKit遇到的问题
小程序·uni-app·实时音视频
2305_7978820912 小时前
AI识图小程序的功能框架设计
人工智能·微信小程序·小程序
goto_w13 小时前
uniapp上使用webview与浏览器交互,支持三端(android、iOS、harmonyos next)
android·vue.js·ios·uni-app·harmonyos
小宝小白13 小时前
【vue3】黑马小兔鲜儿项目uniapp navigationStyle
uni-app
暮雨哀尘13 小时前
微信小程序开发:开发实践
开发语言·算法·微信小程序·小程序·notepad++·性能·技术选型
幽络源小助理15 小时前
微信小程序实验室管理SSM系统设计与实现
微信小程序·小程序
自动花钱机1 天前
WebUI问题总结
前端·javascript·bootstrap·css3·html5