WEUI-Pannel组件源码学习-如何实现一个WEUI-Pannel组件?WEUI-Pannel组件学习分析

前言

今天我们来学习:WEUI-Panel组件!

我们将会实现这样一个效果:

话不多说!我们直接开始!!

正文

我要实现这样的一个组件,我们要编写4个文件panel.html,reset.css,bass.css,panel.css

实现panel.html文件

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title> WEUI源码之Panel组件</title>
    <link rel="stylesheet" href="./base.css">
    <link rel="stylesheet" href="./reset.css">
    <link rel="stylesheet" href="./panel.css">
    <style>
        .box{
            width: 100px;
            height: 100px;
            /* border: 2px solid red; */
            /* background-color: red; */
            /* 轮廓 看过去和border 一样,但是不占空间 */
            /* outline: 2px solid red; */

        }
    </style>
</head>
<body>
      <div class="page">
        <!-- .page__hd+.page__bd '+'为选择器 -->
        <div class="page__hd">
            <!-- page__title是一个标签类名,相对于整个page -->
            <h1 class="page__title">Panel</h1>
            <p class="page__desc">面板</p>

        </div>
        <div class="page__bd">
            <!-- Panel组件 -->
            <div class="weui-panel">
                <div class="weui-panel__hd">
                    图文组合列表
                </div>
                <div class="weui-panel__bd">
                    <!-- 开始了一个新的media-box组件,小组件构成大组件 -->
                    <a href="javascript:;" class="weui-media-box weui-media-box_appmsg">
                        <div class="weui-media-box__hd">
                            <!-- src里面放的是一种编码,几kb左右,这个更小,1kb或者更小 -->
                            <img src="" alt="" class="weui-media-box__thumb">
                        </div>
                        <div class="weio-media-box__bd">
                            <strong class="weui-media-box__title">标题一</strong>
                            <p class="weui-media-box__desc">
                                由各种物质组成的巨型球状天体,叫做星球。星球有一定的形状,有自己的运行轨道
                            </p>
                        </div>
                    </a>
                    <a href="javascript:;" class="weui-media-box weui-media-box_appmsg">
                        <div class="weui-media-box__hd">
                            <!-- src里面放的是一种编码,几kb左右,这个更小,1kb或者更小 -->
                            <img src="" alt="" class="weui-media-box__thumb">
                        </div>
                        <div class="weio-media-box__bd">
                            <strong class="weui-media-box__title">标题二</strong>
                            <p class="weui-media-box__desc">
                                由各种物质组成的巨型球状天体,叫做星球。星球有一定的形状,有自己的运行轨道
                            </p>
                        </div>
                    </a>
               
                <div class="weui-panel__ft">
                    <a href="javascript:" class="weui-cell weui-cell_active weui-cell_access weui-cell_link">
                        <span class="weui-cell__bd">查看更多</span>
                        <span class="weui-cell__ft"></span>
                    </a>    
                </div>
                <div class="weui-panel">
                    <div class="weui-panel__hd">小图文组合列表</div>
                    <div class="weui-panel__bd">
                        <div class="weui-media-box weui-media-box_small-appmsg">
                            <div class="weui-cells">
                                <a aria-labelledby="t1 t2" class="weui-cell weui-cell_active weui-cell_access weui-cell_example" href="javascript:">
                                    <div aria-hidden="true" id="t1" class="weui-cell__hd"><img src="" alt=""></div>
                                    <div aria-hidden="true" id="t2" class="weui-cell__bd weui-cell_primary">
                                        <p>文字标题</p>
                                    </div>
                                    <div class="weui-cell__ft"></div>
                                </a>
                                <a aria-labelledby="t3 t4" class="weui-cell weui-cell_active weui-cell_access weui-cell_example" href="javascript:">
                                    <div aria-hidden="true" id="t3" class="weui-cell__hd"><img src="" alt=""></div>
                                    <div aria-hidden="true" id="t4" class="weui-cell__bd weui-cell_primary">
                                        <p>文字标题</p>
                                    </div>
                                    <div class="weui-cell__ft"></div>
                                </a>
                            </div>
                        </div>
                    </div>
                </div>
                <div class="weui-panel">
                    <div class="weui-panel__hd">文字列表附来源</div>
                    <div class="weui-panel__bd">
                        <div role="link" aria-labelledby="js_p4m1_title js_a11y_comma js_p4m1_desc" aria-describedby="js_p4m1_source js_a11y_comma js_p4m1_time js_a11y_comma js_p4m1_extra" class="weui-media-box weui-media-box_text">
                            <strong aria-hidden="true" class="weui-media-box__title" id="js_p4m1_title">标题一</strong>
                            <p class="weui-media-box__desc" aria-hidden="true" id="js_p4m1_desc">由各种物质组成的巨型球状天体,叫做星球。星球有一定的形状,有自己的运行轨道。</p>
                            <ul class="weui-media-box__info" aria-hidden="true">
                                <li class="weui-media-box__info__meta" aria-hidden="true" id="js_p4m1_source">文字来源</li>
                                <li class="weui-media-box__info__meta" aria-hidden="true" id="js_p4m1_time">时间</li>
                                <li class="weui-media-box__info__meta weui-media-box__info__meta_extra" aria-hidden="true" id="js_p4m1_extra">其它信息</li>
                            </ul>
                        </div>
                    </div>
                </div>
            </div>
        </div>
            </div>
        </div>
      </div>
</body>
</html>
</html>
  1. <div class="page">:这个标签定义了一个页面(Page)的容器。
  2. <div class="page__hd">:这个标签定义了页面的头部(Header)。
  3. <h1 class="page__title">Panel</h1>:这个标签定义了页面头部的标题,显示为 "Panel"。
  4. <p class="page__desc">面板</p>:这个标签定义了页面头部的描述,显示为 "面板"。
  5. <div class="page__bd">:这个标签定义了页面的主体部分(Body)。
  6. <div class="weui-panel">:这个标签定义了一个面板组件。
  7. <div class="weui-panel__hd">:这个标签定义了面板的头部(Header)。
  8. 接下来的文本 "图文组合列表" 是显示在面板头部的内容。
  9. <div class="weui-panel__bd">:这个标签定义了面板的主体部分(Body)。
  10. <a href="javascript:;" class="weui-media-box weui-media-box_appmsg">:这个标签定义了一个链接,该链接包含在一个 weui-media-box 类的 div 中。
  11. 在链接中,有一个 weui-media-box__hd 类的 div,其中包含一个 img 标签,img 标签的 src 属性中包含一个图片的编码。
  12. 在链接中,还有一个 weio-media-box__bd 类的 div,其中包含一个标题和一个描述文本。
  13. div class="weui-panel__ft">:这行代码定义了一个<div>元素,该元素的类名为weui-panel__ft。这个类名是来自微信小程序UI组件库WeUI的一个面板(Panel)组件的一部分。
  14. <a href="javascript:" class="weui-cell weui-cell_active weui-cell_access weui-cell_link">:这行代码定义了一个<a>元素,该元素的类名为weui-cell weui-cell_active weui-cell_access weui-cell_link。这个元素是一个链接,由于href="javascript:",这个链接不会导向其他页面,而是触发一个JavaScript事件。
  15. <span class="weui-cell__bd">查看更多</span>:这行代码定义了一个<span>元素,该元素的类名为weui-cell__bd,显示的内容为"查看更多"。
  16. <div class="weui-panel">:开始一个weui-panel元素,该元素是一个面板(Panel)组件。
  17. <div class="weui-panel__hd">小图文组合列表</div>:在面板的头部(header)添加一个标题,内容为"小图文组合列表"。
  18. <div class="weui-panel__bd">:在面板的主体(body)部分开始。
  19. <div class="weui-media-box weui-media-box_small-appmsg">:创建一个媒体盒子,用于显示图片和文本信息。
  20. <div class="weui-cells">:创建一个包含多个单元格(cell)的集合。
  21. 接下来的两个<a>元素代表两个单元格。每个单元格都包含一个图片、一个标题和一个链接。这些单元格都使用了weui-cellweui-cell_activeweui-cell_accessweui-cell_example这些类
  22. 在每个单元格中,<img src="" alt="">用于显示图片,<p>文字标题</p>用于显示标题,而href="javascript:"则表示这个链接不会导向其他页面,用于触发一个JavaScript事件。
  23. <div class="weui-panel">:开始一个weui-panel元素的定义,该元素通常用于显示一个面板或对话框。
  24. <div class="weui-panel__hd">文字列表附来源</div>:在面板的头部(header)添加一个标题,内容为"文字列表附来源"。
  25. <div class="weui-panel__bd">:在面板的主体(body)部分开始。
  26. <div role="link" aria-labelledby="js_p4m1_title js_a11y_comma js_p4m1_desc" aria-describedby="js_p4m1_source js_a11y_comma js_p4m1_time js_a11y_comma js_p4m1_extra" class="weui-media-box weui-media-box_text">:定义一个可点击的链接元素,它包含一些文本信息和相关来源的描述。这些信息通过ARIA属性进行标识和关联。
  27. <strong aria-hidden="true" class="weui-media-box__title" id="js_p4m1_title">标题一</strong>:定义一个标题文本,内容为"标题一"。
  28. <p class="weui-media-box__desc" aria-hidden="true" id="js_p4m1_desc">由各种物质组成的巨型球状天体,叫做星球。星球有一定的形状,有自己的运行轨道。</p>:定义一个段落文本,内容为对星球的描述。
  29. <ul class="weui-media-box__info" aria-hidden="true">:定义一个无序列表,用于包含文字来源、时间和额外信息等条目。
  30. <li class="weui-media-box__info__meta" aria-hidden="true" id="js_p4m1_source">文字来源</li>:定义一个列表项,用于显示文字来源的信息。
  31. <li class="weui-media-box__info__meta" aria-hidden="true" id="js_p4m1_time">时间</li>:定义一个列表项,用于显示时间信息。
  32. <li class="weui-media-box__info__meta weui-media-box__info__meta_extra" aria-hidden="true" id="js_p4m1_extra">其它信息</li>:定义一个列表项,用于显示额外信息。

注意 :在我们插入图片的时候我们引用的是" alt="" class="weui-media-box__thumb这是一段Base64编码的PNG图片数据.

实现reset.css文件

这个文件相当简单,我们只需要利用它初始化一个我们的全局边距即可!

css 复制代码
*{
    margin: 0;
    padding: 0;
    /* 不同的浏览器margin不同,为了保持不同的浏览器体验一样 */
    outline: 0 ;/* input a 聚焦时或者高亮时用 重置样式,让样式无差别*/
    /* 把总大小变为content大小 */
    /* box-sizing: border-box; 盒子模型方式切换*/
}

实现Panel.css文件

css 复制代码
/* 面板组件 */
.weui-panel{
    background-color: var(--weui-BG-2);
    margin-top: 10px;
    position: relative;
    /* 超出隐藏,不要有滚动框 */
    overflow: hidden;

}
/*.weui-panel:first-child 选中的是一类元素,所有的weui-panel的第一个,如果是第一个没必要margin-top 0, */
/* 其余的会和前面的panel 有个margin-top 如果:和英文之间加了空歌 */
/* .weuipanel */
.weui-panel:first-child{
    margin-top: 0px;
}
.weiui-panel__hd{
    padding: 16px 16px 13px;
    color: var(--weui-FG-0);
    font-size: 15px;
    font-weight: 500;
    position: relative;
}

在这一段代码中

  1. .weui-panel 的背景色被设置为 --weui-BG-2,这是一个CSS变量,通常在HTML元素的class或id选择器中定义。margin-top: 10px; 表示这个元素的上边距为10像素。position: relative; 表示这个元素的位置相对于其正常位置进行定位。overflow: hidden; 表示如果这个元素的内容超出其边界,那么超出的部分会被隐藏,不会出现滚动条。
  2. .weui-panel:first-child 是选择所有 .weui-panel 的第一个元素。这里将它的 margin-top 设置为0,也就是说,如果这个元素是 .weui-panel 类的第一个元素,那么它的上边距将被设置为0。
  3. .weui-panel__hd.weui-panel 的一个子元素,可能是一个header或者标题部分。这个元素的 padding 被设置为16px 16px 13px,也就是说,这个元素的上、左右、下都有填充。color 被设置为 --weui-FG-0,这同样是一个CSS变量,通常在HTML元素的class或id选择器中定义。font-size 被设置为15px,font-weight 被设置为500,表示字体大小和粗细。position: relative; 表示这个元素的位置相对于其正常位置进行定位。

实现base.css文件

css 复制代码
.page{
    /* 手机滚屏阅读的常见操作! */
    /* 移动端的占满整个页面写法 */
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    /* bfc属性,很重要,超出则滚动 */
    overflow-y: auto;
    /* 让滚动如丝般顺滑 css考点 和手touch粘合 手机端浏览器 */
    /* 移动端浏览器内核前缀都是-webkit
    overflow-scrolling在实验阶段
     */
    -webkit-overflow-scrolling: touch;
    /* 把盒子模型设置为IE盒子模型 */
    box-sizing: border-box;
    z-index: 1;   
}
body{
    /* 格式以--开始 */
    --weui-BG-0:rgb(17, 241, 253);
    /* 方便统一更改 管理 利用 皮肤更换 */
    --weui-FG-1:rgb(0, 0, 0);
    --weui-BG-2:rgb(17, 241, 253);
}
.page,body{
    /* weui技术很激进 css4的变量  */
    background-color: var(--weui-BG-0);

}
body{
    color: rgba(7, 2, 2, 0.8);
}
.page__hd{
    margin-top: 10px;
    padding: 40px;
    width: 50px;
    height: 50px;
    background-color: rgb(13, 193, 13); 
    
}
.page__title{
    text-align: left;
    font-size: 20px;
    font-weight: 400;
    
}
.page__desc{
    margin-top: 4px;
    /* 文字的背景颜色,新的变量,方便统一修改 */
    color: var(--weui-FG-1);
    text-align:left;
    font-size: 14px;
    
}
.page__bd{
    padding-bottom: 20px;
}

这一段代码:

  1. .page:这个类定义了一个页面样式,它被设置为绝对定位,并占据整个屏幕。通过设置overflow-y: auto;,当内容超出页面的高度时,会出现滚动条。-webkit-overflow-scrolling: touch;是为了让滚动更加平滑。box-sizing: border-box;是让元素的边框和内边距都包含在元素的总宽度内。z-index: 1;是设置元素的堆叠顺序。
  2. body:这个元素定义了一些背景颜色和字体颜色。其中,--weui-BG-0, --weui-FG-1--weui-BG-2 是CSS变量,用于存储颜色值,方便统一修改和管理。
  3. .page, body:这两者都设置了背景颜色,分别是 --weui-BG-0--weui-BG-2
  4. .page__hd:这个类定义了页面头部的样式,其中 padding: 40px; 是设置元素的内边距。
  5. .page__title:这个类定义了页面标题的样式,包括文字对齐方式、字体大小和粗细。
  6. .page__desc:这个类定义了页面描述的样式,包括上边距、文字颜色、对齐方式和字体大小。
  7. .page__bd:这个类定义了页面主体的样式,其中 padding-bottom: 20px; 是设置元素的下边距。

最后,我们实现的效果

如果大家有任何想法和指正!欢迎大家留言!!点个小赞支持鼓励一下吧!🌹🌹🌹

相关推荐
gnip10 小时前
链式调用和延迟执行
前端·javascript
SoaringHeart10 小时前
Flutter组件封装:页面点击事件拦截
前端·flutter
杨天天.10 小时前
小程序原生实现音频播放器,下一首上一首切换,拖动进度条等功能
前端·javascript·小程序·音视频
Dragon Wu11 小时前
React state在setInterval里未获取最新值的问题
前端·javascript·react.js·前端框架
Jinuss11 小时前
Vue3源码reactivity响应式篇之watch实现
前端·vue3
YU大宗师11 小时前
React面试题
前端·javascript·react.js
木兮xg11 小时前
react基础篇
前端·react.js·前端框架
ssshooter11 小时前
你知道怎么用 pnpm 临时给某个库打补丁吗?
前端·面试·npm
IT利刃出鞘12 小时前
HTML--最简的二级菜单页面
前端·html
yume_sibai12 小时前
HTML HTML基础(4)
前端·html