前言:

项目包自取:
链接:https://pan.baidu.com/s/1ZMmiWSXq7290D_j0wUJ09Q
提取码:6o0l

夜神模拟器的配置和下载过程:
https://blog.csdn.net/weixin_45678130/article/details/113540631

code:

此项目的实现原理
在这里插入图片描述
在这里插入图片描述

index.html(js和body部分):

<body>
	<header class="mui-bar mui-bar-nav">
		<h1 class="mui-title">微信</h1>
	</header>

	<nav class="mui-bar mui-bar-tab">
		<a class="mui-tab-item mui-active" href="sub1.html">
			<span class="mui-icon mui-icon-chatbubble"></span>
			<span class="mui-tab-label">微信</span>
		</a>
		<a class="mui-tab-item" href="sub2.html">
			<span class="mui-icon mui-icon-contact" ></span>
			<span class="mui-tab-label">通讯录</span>
		</a>
		<a class="mui-tab-item" href="sub3.html">
			<span class="mui-icon mui-icon-navigate"></span>
			<span class="mui-tab-label">发现</span>
		</a>
		<a class="mui-tab-item" href="sub4.html">
			<span class="mui-icon mui-icon-person"></span>
			<span class="mui-tab-label"></span>
		</a>
	</nav>
</body>
<script type="text/javascript" charset="utf-8">
      	mui.init();//初始化页面应用mui
		
		//mui加载完成事件
		mui.plusReady(function(){
			//定义子页面的数组
			var subPages=["sub1.html","sub2.html","sub3.html","sub4.html"];
			//子页面样式
			var subPageStyle={
				top:"44px",
				bottom:"50px"
			};
			//主webview
			var mainView=plus.webview.currentWebview();
			//遍历数组,根据每个子页面url创建webview
			for(var i=0;i<subPages.length;i++){
				var url=subPages[i];
				//创建webview
				//函数原型plus.webview.create(url,id,style),返回webview对象
				var subView=plus.webview.create(url,url,subPageStyle);
				//隐藏子webview
				subView.hide();
				//把子webview加到主Webview
				mainView.append(subView);
			}
			//把第一个subView显示出来
			plus.webview.show(subPages[0]);
			
			//给每个导航栏目设置tap事件(轻击事件,注意不是tab)
			//网页事件onclick,click在这里无效
			//原型mui(html元素的父选择器).on(事件名,注册事件的html元素选择器,事件)
			mui(".mui-bar-tab").on("tap","a",function(){
				//获取事件源对象的属性的值
				var id=this.getAttribute("href");
				//设置子页面的显示
				plus.webview.show(id);
			});
		});
		
    </script>

然后放一下聊天页面和朋友圈的sub页面 其余的可以见项目包
sub1.html:

<div class="mui-content">
			<ul class="mui-table-view">
				<li class="mui-table-view-cell mui-media">
					<a href="javascript:;" title="幸福">
						<img class="mui-media-object mui-pull-left" src="img/f1.jpg">
						<div class="mui-media-body">
							幸福
							<p class="mui-ellipsis">能和心爱的人一起睡觉,是件幸福的事情;可是,打呼噜怎么办?</p>
						</div>
					</a>
				</li>
				<li class="mui-table-view-cell mui-media">
					<a href="javascript:;" title="木屋">
						<img class="mui-media-object mui-pull-left" src="img/f2.jpg">
						<div class="mui-media-body">
							木屋
							<p class="mui-ellipsis">想要这样一间小木屋,夏天挫冰吃瓜,冬天围炉取暖.</p>
						</div>
					</a>
				</li>
				<li class="mui-table-view-cell mui-media">
					<a href="javascript:;" title="CBD">
						<img class="mui-media-object mui-pull-left" src="img/f3.jpg">
						<div class="mui-media-body">
						    CBD
							<p class="mui-ellipsis">烤炉模式的城,到黄昏,如同打翻的调色盘一般.</p>
						</div>
					</a>
				</li>
				<li class="mui-table-view-cell mui-media">
					<a href="javascript:;" title="中国移动10086">
						<img class="mui-media-object mui-pull-left" src="img/f4.jpg">
						<div class="mui-media-body">
						    中国移动10086
							<p class="mui-ellipsis">点我!!免费领2G流量!!</p>
						</div>
					</a>
				</li>
				<li class="mui-table-view-cell mui-media">
					<a href="javascript:;" title="微信团队">
						<img class="mui-media-object mui-pull-left" src="img/f5.jpg">
						<div class="mui-media-body">
						    微信团队
							<p class="mui-ellipsis">欢迎你再次回到微信。如果你在使用过程中有任何的问题或建议,记得给我发信反馈哦。
</p>
						</div>
					</a>
				</li>
			</ul>
		</div>
<script type="text/javascript">
			mui.init();
			mui.plusReady(function(){
				mui(".mui-table-view-cell").on("tap","a",function(){
					//获取好友名称
					var title=this.getAttribute("title");
					//打开聊天页面
					mui.openWindow({
						url:"sub1/chat.html",
						id:"sub1/chat.html",
						extras:{//键值对
						  name:title//自定义扩展参数,可以用来处理页面间传值
						},
						show:{
						  autoShow:true,//页面loaded事件发生后自动显示,默认为true
						  aniShow:"slide-in-right",//页面显示动画,默认为”slide-in-right“;
						  duration:100//页面动画持续时间,Android平台默认100毫秒,iOS平台默认200毫秒;
						},
						waiting:{
						  autoShow:true,//自动显示等待框,默认为true
						  title:'正在加载...'//等待对话框上显示的提示内容
						}
					})
				});
			});
		</script>

chat.html:(实现类似功能)
在这里插入图片描述
点击图标可以发送图片,然后可以发送信息至页面

sub3.html:

<div class="mui-content">
				<ul class="mui-table-view">
					<li class="mui-table-view-cell  mui-left" id="friend">
						<span class="mui-icon mui-icon-pengyouquan"> &nbsp;&nbsp;朋友圈</span>
					</li>
				</ul>
				<br />
				<ul class="mui-table-view">
					<li class="mui-table-view-cell  mui-left">
						<span class="mui-icon mui-icon-camera"/> &nbsp;&nbsp;扫一扫
					</li>
					<li class="mui-table-view-cell  mui-left">
						<span class="mui-icon mui-icon-spinner mui-spin"/> &nbsp;&nbsp;摇一摇
					</li>
				</ul>
				<br /> 
				<ul class="mui-table-view">
					<li class="mui-table-view-cell  mui-left">
						<span class="mui-icon mui-icon-home"/> &nbsp;&nbsp;购物
					</li>
					<li class="mui-table-view-cell  mui-left">
					<span class="mui-icon mui-icon-star"/> &nbsp;&nbsp;游戏
					</li>
				</ul>
			</div>
<script type="text/javascript">
			mui.init();
			mui.plusReady(function(){
			//给朋友圈注册轻击事件
			var friend=document.getElementById("friend");
			friend.addEventListener("tap",function(){
				mui.openWindow({
					url:"sub3/friend.html",
					id:"sub3/friend.html",
					show:{
					  autoShow:true,//页面loaded事件发生后自动显示,默认为true
					  aniShow:"slide-in-right",//页面显示动画,默认为”slide-in-right“;
					  duration:100//页面动画持续时间,Android平台默认100毫秒,iOS平台默认200毫秒;
					},
					waiting:{
					  autoShow:true,//自动显示等待框,默认为true
					  title:'正在加载...'//等待对话框上显示的提示内容
					}
				})
			});

		});
		</script>

friend.html:
在这里插入图片描述

其中用到了下拉刷新容器pullRefresh

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport"
	content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
<meta name="apple-mobile-web-app-capable" content="yes">

<title>朋友圈</title>
<script src="../js/mui.min.js"></script>
<link href="../css/mui.min.css" rel="stylesheet"/>
<link rel="stylesheet" type="text/css" href="../css/main.css"/>
<link rel="stylesheet" href="../css/friend.css">
<link rel="stylesheet" href="../css/iconfont.css">
<link rel="stylesheet prefetch" href="../css/photoswipe.css">
<link rel="stylesheet prefetch" href="../css/default-skin.css">
		<script>
			
			mui.init({
				pullRefresh: {
					container: '#pullrefresh',
					down: {
						style:'circle',
						callback: pulldownRefresh
					},
					up: {
						auto:true,
						contentrefresh: '正在加载...',
						callback: pullupRefresh
					}
				}
			});
			
			var count = 0;
			function pullupRefresh() {
				setTimeout(function() {
					mui('#pullrefresh').pullRefresh().endPullupToRefresh((++count > 2)); //参数为true代表没有更多数据了。
					var table = document.body.querySelector('.ultable');
					var cells = document.body.querySelectorAll('.mui-table-view-cell');
					var newCount = cells.length>0?5:20;//首次加载20条,满屏
					for (var i = cells.length, len = i + newCount; i < len; i++) {
						var li = document.createElement('li');
						li.className = 'mui-table-view-cell';
						li.innerHTML = '<a class="mui-navigate-right">Item ' + (i + 1) + '</a>';
						table.appendChild(li);
					}
				}, 1500);
			}

			function addData() {
				var table = document.body.querySelector('.ultable');
				var cells = document.body.querySelectorAll('.mui-table-view-cell');
				for(var i = cells.length, len = i + 5; i < len; i++) {
					var li = document.createElement('li');
					li.className = 'mui-table-view-cell';
					li.innerHTML = '<a class="mui-navigate-right">Item ' + (i + 1) + '</a>';
					//下拉刷新,新纪录插到最前面;
					table.insertBefore(li, table.firstChild);
				}
			}
			/**
			 * 下拉刷新具体业务实现
			 */
			function pulldownRefresh() {
				setTimeout(function() {
					addData();
					mui('#pullrefresh').pullRefresh().endPulldownToRefresh();
					mui.toast("为你推荐了5篇文章");
				}, 1500);
			}
		</script>
</head>

<body style="background-color: #fff;">
	<header class="mui-bar mui-bar-nav">
		<a class="mui-action-back mui-icon mui-icon-left-nav mui-pull-left"></a>
		<h1 class="mui-title">朋友圈</h1>
	</header>
	
	<div id="_contain">
		<div class="banner" style="position: relative;">
			<div class="top_bg"></div>
			<div style="width:80px; height:80px;position: absolute;background-color: #F3F3F7;right: 10px;bottom: -30px;">
				<img src="../img/tx.jpg" style="width:96%; margin: 2%;">
			</div>
			<div style="position: absolute;right: 100px;bottom: 10px;color: white;">
				在路上的愚人
			</div>
		</div>

	<!--下拉刷新容器-->
	<div id="pullrefresh" class="mui-content mui-scroll-wrapper">
		<div class="mui-scroll">
			
		<div class="contain" style="margin: 40px 0 0;">
			<ul class="ultable"> 
				<li>
					<div class="body">
						<div class="logo">
							<img src="../img/tx2.jpg">
						</div>
						<div class="text">
							<div class="title">小黄人</div>
							<div class="txt">在宇宙中未知的地方有一个由12个人类殖民地组成的星际国家,人类为了方便制造了Cylons(机器人)为人类服务,但Cylons起来反抗人类,双方在血战之后停火,Cylons离开了殖民地去建立自己的家园。40年的和平让<span id="p1">...</span><span id="txt1" style="display:none;">人类放松了警惕,Cylons通过人类内部的间谍瘫痪了人类的防御系统,摧毁了Battlestar舰队,用核武器将殖民地的城市化为灰烬。Battlestar Galactica是唯一一艘幸存的航母,它在舰长Adama的指挥下带领几十艘各式各样的民船和近5万名幸存者逃离了殖民地的行星系统,开始了寻找人类的第13个殖民地——地球——的旅程。</span></div>
							<div style="color: #88B1C5;" onclick="more(this,'1')">全文</div>
							<div class="my-gallery" data-pswp-uid="1">
							<figure><span>
							  <a href="../img/th1.jpg" data-size="670x712">
							  <img style="width:80%;" src="../img/th1.jpg">
							  </a></span>
							</figure>
							  </div>
							<div class="tm">
								<div class="fl">1分钟前</div>
								<div class="fr">评论</div>
							</div>
							<div class="cmt">
								<div class="fav line"><i class="iconfont">&#xe616;</i>小豪,李小爱</div>
								<div><span>小豪:</span>什么</div>
								<div><span>淘淘:</span>I use owl carousel to generate a slider, but at the same time I want to use Photoswipe, but I can't. When I use the Owl carousel plugin, the slider's inserted into the code with a speciel markup, where each item (image) has a class of .item and the image is located 3 layers deep into that div.</div>
							</div>
						</div>
					</div>
				</li>
				<li>
					<div class="body">
						<div class="logo"><img src="../img/tx3.jpg"></div>
						<div class="text">
							<div class="title">小清新</div>
							<div class="txt">买了一个更帅的电饭锅,可以手机远程操制的,开心</div>
							<!--data-pswp-uid 是每个gallery的id不能重复-->
							<div class="my-gallery" data-pswp-uid="2">
							<figure>
								<div><a href="../img/s5.jpg" data-size="286x220"><img style="height:100%;" src="../img/s5.jpg"></a></div>
								<figcaption style="display:none;">在这里可增加图片描述</figcaption>
							</figure>
							<figure>
								<div><a href="../img/sb1.jpg" data-size="640x426"><img style="height:100%;" src="../img/sb1.jpg"></a></div>
								<figcaption style="display:none;">在这里可增加图片描述2</figcaption>
							</figure>
							<figure>
								<div><a href="../img/sb3.jpg" data-size="768x1024"><img style="width:100%;" src="../img/sb3.jpg"></a></div>
								<figcaption style="display:none;">在这里可增加图片描述3</figcaption>
							</figure>
							<figure>
								<div><a href="../img/sb4.jpg" data-size="900x596"><img style="height:100%;" src="../img/sb4.jpg"></a></div>
								<figcaption style="display:none;">在这里可增加图片描述4</figcaption>
							</figure>
							<figure>
								<div><a href="../img/y1.jpg" data-size="1200x1200"><img  style="height:100%;" src="../img/y1.jpg"></a></div>
								<figcaption style="display:none;">在这里可增加图片描述5在这里可增加图片描述5在这里可增加图片描述5</figcaption>
							</figure>
							</div>
							<div class="tm">
								<div class="fl">2分钟前</div>
								<div class="fr">评论</div>
							</div>
							<div class="cmt">
								<div class="fav"><i class="iconfont">&#xe616;</i>ANTHONY,☆Sanly☆</div>
								<div><span>ANTHONY:</span>这么先进,和我家的那台一样,打个电话,照样有饭吃,一键式,还带做菜功能,还能洗碗聊天晾衣服</div>
								<div><span>☆Sanly☆:</span>远程?还有洗米放水功能?</div>
							</div>
						</div>
					</div>
				</li>
				
			</ul>
		</div>

    </div>
    </div>
	</div>
	
	<!-- Root element of PhotoSwipe. Must have class pswp. -->
<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">

    <!-- Background of PhotoSwipe. 
         It's a separate element as animating opacity is faster than rgba(). -->
    <div class="pswp__bg"></div>

    <!-- Slides wrapper with overflow:hidden. -->
    <div class="pswp__scroll-wrap">

        <!-- Container that holds slides. 
            PhotoSwipe keeps only 3 of them in the DOM to save memory.
            Don't modify these 3 pswp__item elements, data is added later on. -->
        <div class="pswp__container">
            <div class="pswp__item"></div>
            <div class="pswp__item"></div>
            <div class="pswp__item"></div>
        </div>

        <!-- Default (PhotoSwipeUI_Default) interface on top of sliding area. Can be changed. -->
        <div class="pswp__ui pswp__ui--hidden">

            <div class="pswp__top-bar">

                <!--  Controls are self-explanatory. Order can be changed. -->

                <div class="pswp__counter"></div>

                <button class="pswp__button pswp__button--close" title="Close (Esc)"></button>

                <button class="pswp__button pswp__button--share" title="Share"></button>

                <button class="pswp__button pswp__button--fs" title="Toggle fullscreen"></button>

                <button class="pswp__button pswp__button--zoom" title="Zoom in/out"></button>

                <!-- element will get class pswp__preloader--active when preloader is running -->
                <div class="pswp__preloader">
                    <div class="pswp__preloader__icn">
                      <div class="pswp__preloader__cut">
                        <div class="pswp__preloader__donut"></div>
                      </div>
                    </div>
                </div>
            </div>

            <div class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap">
                <div class="pswp__share-tooltip"></div> 
            </div>

            <button class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)">
            </button>

            <button class="pswp__button pswp__button--arrow--right" title="Next (arrow right)">
            </button>

            <div class="pswp__caption">
                <div class="pswp__caption__center"></div>
            </div>

        </div>
</div>
</div>
</body>
<script src="../js/jquery-3.3.1.min.js"></script>
<script src="../js/photoswipe.js"></script>
<script src="../js/photoswipe-ui-default.min.js"></script>
<script type="text/javascript">
	var initPhotoSwipeFromDOM = function(gallerySelector) {

    // 解析来自DOM元素幻灯片数据(URL,标题,大小...)
    // (children of gallerySelector)
    var parseThumbnailElements = function(el) {
        var thumbElements = el.childNodes,
            numNodes = thumbElements.length,
            items = [],
            figureEl,
            linkEl,
            size,
            item,
			divEl;

        for(var i = 0; i < numNodes; i++) {

            figureEl = thumbElements[i]; // <figure> element

            // 仅包括元素节点
            if(figureEl.nodeType !== 1) {
                continue;
            }
			divEl = figureEl.children[0];
            linkEl = divEl.children[0]; // <a> element
			
            size = linkEl.getAttribute('data-size').split('x');

            // 创建幻灯片对象
            item = {
                src: linkEl.getAttribute('href'),
                w: parseInt(size[0], 10),
                h: parseInt(size[1], 10)
            };



            if(figureEl.children.length > 1) {
                // <figcaption> content
                item.title = figureEl.children[1].innerHTML; 
            }

            if(linkEl.children.length > 0) {
                // <img> 缩略图节点, 检索缩略图网址
                item.msrc = linkEl.children[0].getAttribute('src');
            } 

            item.el = figureEl; // 保存链接元素 for getThumbBoundsFn
            items.push(item);
        }

        return items;
    };

    // 查找最近的父节点
    var closest = function closest(el, fn) {
        return el && ( fn(el) ? el : closest(el.parentNode, fn) );
    };

    // 当用户点击缩略图触发
    var onThumbnailsClick = function(e) {
        e = e || window.event;
        e.preventDefault ? e.preventDefault() : e.returnValue = false;

        var eTarget = e.target || e.srcElement;

        // find root element of slide
        var clickedListItem = closest(eTarget, function(el) {
            return (el.tagName && el.tagName.toUpperCase() === 'FIGURE');
        });

        if(!clickedListItem) {
            return;
        }

        // find index of clicked item by looping through all child nodes
        // alternatively, you may define index via data- attribute
        var clickedGallery = clickedListItem.parentNode,
            childNodes = clickedListItem.parentNode.childNodes,
            numChildNodes = childNodes.length,
            nodeIndex = 0,
            index;

        for (var i = 0; i < numChildNodes; i++) {
            if(childNodes[i].nodeType !== 1) { 
                continue; 
            }

            if(childNodes[i] === clickedListItem) {
                index = nodeIndex;
                break;
            }
            nodeIndex++;
        }



        if(index >= 0) {
            // open PhotoSwipe if valid index found
            openPhotoSwipe( index, clickedGallery );
        }
        return false;
    };

    // parse picture index and gallery index from URL (#&pid=1&gid=2)
    var photoswipeParseHash = function() {
        var hash = window.location.hash.substring(1),
        params = {};

        if(hash.length < 5) {
            return params;
        }

        var vars = hash.split('&');
        for (var i = 0; i < vars.length; i++) {
            if(!vars[i]) {
                continue;
            }
            var pair = vars[i].split('=');  
            if(pair.length < 2) {
                continue;
            }           
            params[pair[0]] = pair[1];
        }

        if(params.gid) {
            params.gid = parseInt(params.gid, 10);
        }

        return params;
    };

    var openPhotoSwipe = function(index, galleryElement, disableAnimation, fromURL) {
        var pswpElement = document.querySelectorAll('.pswp')[0],
            gallery,
            options,
            items;

        items = parseThumbnailElements(galleryElement);

        // 这里可以定义参数
        options = {
          barsSize: { 
            top: 100,
            bottom: 100
          }, 
		   fullscreenEl : false,
			shareButtons: [
			{id:'wechat', label:'分享微信', url:'#'},
			{id:'weibo', label:'新浪微博', url:'#'},
			{id:'download', label:'保存图片', url:'{{raw_image_url}}', download:true}
			],

            // define gallery index (for URL)
            galleryUID: galleryElement.getAttribute('data-pswp-uid'),

            getThumbBoundsFn: function(index) {
                // See Options -> getThumbBoundsFn section of documentation for more info
                var thumbnail = items[index].el.getElementsByTagName('img')[0], // find thumbnail
                    pageYScroll = window.pageYOffset || document.documentElement.scrollTop,
                    rect = thumbnail.getBoundingClientRect(); 

                return {x:rect.left, y:rect.top + pageYScroll, w:rect.width};
            }

        };

        // PhotoSwipe opened from URL
        if(fromURL) {
            if(options.galleryPIDs) {
                // parse real index when custom PIDs are used 
                for(var j = 0; j < items.length; j++) {
                    if(items[j].pid == index) {
                        options.index = j;
                        break;
                    }
                }
            } else {
                // in URL indexes start from 1
                options.index = parseInt(index, 10) - 1;
            }
        } else {
            options.index = parseInt(index, 10);
        }

        // exit if index not found
        if( isNaN(options.index) ) {
            return;
        }

        if(disableAnimation) {
            options.showAnimationDuration = 0;
        }

        // Pass data to PhotoSwipe and initialize it
        gallery = new PhotoSwipe( pswpElement, PhotoSwipeUI_Default, items, options);
        gallery.init();
    };

    // loop through all gallery elements and bind events
    var galleryElements = document.querySelectorAll( gallerySelector );

    for(var i = 0, l = galleryElements.length; i < l; i++) {
        galleryElements[i].setAttribute('data-pswp-uid', i+1);
        galleryElements[i].onclick = onThumbnailsClick;
    }

    // Parse URL and open gallery if it contains #&pid=3&gid=1
    var hashData = photoswipeParseHash();
    if(hashData.pid && hashData.gid) {
        openPhotoSwipe( hashData.pid ,  galleryElements[ hashData.gid - 1 ], true, true );
    }
	};

	// execute above function
	initPhotoSwipeFromDOM('.my-gallery');

	
	$(".my-gallery>figure>div").each(function(){
		$(this).height($(this).width());
	});
	function more(obj,id) {
 		if ($('#txt'+id).is(":hidden")) {
 			$('#p'+id).hide();
 	 		$('#txt'+id).show();
 	 		obj.innerHTML='收起';
 		} else {
 			$('#p'+id).show();
 	 		$('#txt'+id).hide();
 	 		obj.innerHTML='全文';
 		}
 	}
</script>
</html>

Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐