左中右布局的两种常用方法

2 篇文章 0 订阅

1、float+absolute

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style type="text/css">
        #content{
            position: relative;
            width:100%;
            height:300px;
        }
        .left{
            float: left;
            width: 200px;
            height:100%;
            background-color: #00a0dc;
        }
        .middle{
            position: absolute;
            top:0;
            bottom:0;
            left:200px;
            right: 300px;
            background-color: red;
        }
        .right{
            float: right;
            height:100%;
            width: 300px;
            background-color: #00a0dc;
        }
    </style>
</head>
<body>
<div id="content">
    <div class="left"></div>
    <div class="middle"></div>
    <div class="right"></div>
</div>
</body>
</html>

 

2、display:flex;flex:1

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        *{
            margin: 0;
            padding: 0;
        }
        #content {
            display: flex;
            width: 100%;
            height: 200px;
        }
        #left {
           flex:0 0 200px;
            height: 100%;
            background-color: blue;
        }
        #middle{
            flex: 1;
            background-color: red;
        }
        #right {
            flex:0 0 200px;
            height: 100%;
            background-color: blue;
        }
    </style>
</head>

<body>
<div id="content">
    <div id="left"> </div>
    <div id="middle"></div>
    <div id="right"></div>
</div>
</body>

</html>

 

 

实现左右联动的方式有很多种,其中一种常用方法是利用 `RecyclerView` 的滑动监听来实现。 首先,需要在布局文件中定义两个 `RecyclerView`,分别表示左侧和右侧的列表,如下所示: ```xml <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="horizontal"> <androidx.recyclerview.widget.RecyclerView android:id="@+id/left_rv" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> <androidx.recyclerview.widget.RecyclerView android:id="@+id/right_rv" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> </LinearLayout> ``` 接下来,在代码中分别获取这两个 `RecyclerView`,并设置它们的布局管理器和适配器。 ```java RecyclerView leftRv = findViewById(R.id.left_rv); RecyclerView rightRv = findViewById(R.id.right_rv); // 设置布局管理器 leftRv.setLayoutManager(new LinearLayoutManager(this)); rightRv.setLayoutManager(new LinearLayoutManager(this)); // 设置适配器 leftRv.setAdapter(leftAdapter); rightRv.setAdapter(rightAdapter); ``` 接着,在左侧列表的滑动监听中获取当前可见的第一个 item,然后将右侧列表滚动到对应的位置。具体实现如下: ```java leftRv.addOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); int firstVisibleItemPosition = ((LinearLayoutManager) leftRv.getLayoutManager()).findFirstVisibleItemPosition(); rightRv.scrollToPosition(firstVisibleItemPosition); } }); ``` 这样,当左侧列表滑动时,右侧列表也会跟着滑动,实现了左右联动的效果。需要注意的是,这种实现方式只适用于两个列表的 item 数量相同的情况,如果两个列表的 item 数量不同,则需要进行一些额外的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值