【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

相关推荐
小小王app小程序开发1 小时前
招工招聘小程序运营风险清单:资质备案 + 信息审核 + 服务履约避坑实操
小程序
2501_915921432 小时前
混合开发应用安全方案,在多技术栈融合下构建可持续、可回滚的保护体系
android·安全·ios·小程序·uni-app·iphone·webview
q_19132846952 小时前
基于SpringBoot2+Vue2+uniapp的考研社区论坛网站及小程序
java·vue.js·spring boot·后端·小程序·uni-app·毕业设计
pearbing3 小时前
多平台发力:小程序搜索优化的实用策略指南
小程序·小程序搜索排名·小程序优化·小程序搜索排名优化·小程序搜索优化·小程序seo
2501_915106323 小时前
Charles抓包怎么用 Charles抓包工具详细教程、网络调试方法、HTTPS配置与手机抓包实战
网络·ios·智能手机·小程序·https·uni-app·webview
apollo_qwe3 小时前
基于 uView 的 u-picker 自定义时分秒选择器实现(支持反显)
uni-app
00后程序员张4 小时前
Fastlane 结合 开心上架,构建跨平台可发布的 iOS 自动化流水线实践
android·运维·ios·小程序·uni-app·自动化·iphone
游戏开发爱好者84 小时前
iOS 性能测试的工程化方法,构建从底层诊断到真机监控的多工具测试体系
android·ios·小程序·https·uni-app·iphone·webview
2501_916008895 小时前
iOS App 混淆的真实世界指南,从构建到成品 IPA 的安全链路重塑
android·安全·ios·小程序·uni-app·cocoa·iphone
计算机毕设指导65 小时前
基于微信小程序的健康指导平台【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven