ios网页免签封装APP隐藏顶部网址教程,详细干货分享

2021-04-16T10:17:00

这个教程在互站网要花五百块钱买,里面的傻瓜式js还有人做成工具利用信息差卖,而且全网都找不到其它的可用教程。
一般情况下,很多站长会把自己的网站手机版打包成app,安卓的自然简单,直接用网上各种工具或者一些比如Hbuilder之类的IDE直接打包。但是ios网上就没有什么打包教程了,如果打包成原生ipa文件甚至还需要证书,或者手机越狱才能安装,但是实际上ios网页打包是有解决方案的,具体可以看我之前的教程(这个教程很重要,涉及到免签打包工具),建议看的时候无视之前的,直接从“打包苹果应用”看起:

uniapp苹果ios端免签打包带分发,转换思路玩法

虽然教程里面是uniapp的代码,但是实际上和网页打包一致,所以有网页打包需求的可以直接参考之前的教程,下载工具完成打包即可。

但是ios打包完成后,会有三个明显的问题:

1.顶部始终会出现不安全提示
2.普通的网页情况下,点击任何链接都会跳出类似浏览器的新页面,或者干脆真的到浏览器了
3.点击链接会跳出带网址的头部,使用起来不像app

解决方案如下:

问题一:顶部始终会出现不安全提示

这是最好解决的问题,那就是直接给网站配置https,也就是配置下ssl证书,再重新用工具打包,就可以解决第一个问题。

问题二:普通的网页情况下,点击任何链接都会跳出到浏览器

如果你已经操作了问题三的步骤,可无视问题二

这个问题的解决方法,是在网页的头部head或者通用的某个页面区块或者通用js中,加入如下代码:

<script type="text/javascript">
if(("standalone" in window.navigator) && window.navigator.standalone){
    var noddy, remotes = false;
    document.addEventListener('click', function(event) {
    noddy = event.target;
    while(noddy.nodeName !== "A" && noddy.nodeName !== "HTML") {
    noddy = noddy.parentNode;
    }
    if('href' in noddy && noddy.href.indexOf('http') !== -1 && (noddy.href.indexOf(document.location.host) !== -1 || remotes))
    {
    event.preventDefault();
    document.location.href = noddy.href;
    }
    },false);
}
</script>

上面这段js的原理是,识别到ios设备浏览,并将所有的可跳转a标签,都变为js动态跳转形式,这样就可以防止跳出到浏览器。但是还会存在第三个问题,那就是点击任何链接,跳出的页面都会带一个有网址的头部,非常影响界面效果和体验。

问题三:点击链接会跳出带网址的头部,使用起来不像app

在网站的根目录(其它目录也可以),新建一个html后缀的文件,将以下的代码放进去,封装的网站首页修改成你的主页地址。

<!DOCTYPE html>

<html>
    <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <!-- <meta name="apple-mobile-web-app-status-bar-style" content="black"> -->
    <meta name="apple-mobile-web-app-title" content="Meta Game">
    <link rel="apple-touch-icon" href="/icon.png">
    <link rel="apple-touch-startup-image" href="/startup.png">
        <title>Meta Game</title>
    <style>
      *{
        margin: 0;
        padding: 0;
      }
      html {
        width: 100vw;
        height: 100vh;
        padding: 0;
        margin: 0;
        overflow: hidden;
      }
      body {
        margin: 0px;
        overflow: hidden;
        box-sizing: border-box;
        padding: 0;
      }
      iframe {
        border: 0px;
        height: 100vh;
        overflow: hidden;
        width: 100%;
      }
    </style>
    </head>
    <body>

    <iframe frameborder="0" scrolling="auto" src="你的网址" mce_src="你的网址"></iframe>
    </body>
</html>

然后重新回到打包软件,将里面的web地址一直精确到刚才新建的html文件。这样再通过ios设备打开app,就会发现点击链接也不会跳出头部了。这段代码的原理就是,新建一个节目,用iframe嵌套的原理包裹整个网站,所以里面的网站无论怎么点击,都没有出现页面地址的变更,于是就不会出现头部了。

同时,根据ios Web Clip的特性,还可以定义图标和启动图。

<link rel="apple-touch-icon" href="/icon.png">
<link rel="apple-touch-startup-image" href="/startup.png">

<link rel="apple-touch-icon"
href="/icon.png">:该标签指定了网站添加到主屏幕上时的图标,以供用户识别和点击。可以使用 PNG 或 JPG
格式的图片,建议尺寸为 180px x 180px,透明度为 0 或 1 的区域将被 iOS
系统自动填充为白色或黑色。该标签也可以使用多个尺寸的图片,以便不同大小的设备显示不同的图标。 <link
rel="apple-touch-startup-image"
href="/startup.png">:该标签指定了网站启动时的加载画面,可以使用 PNG 格式的图片,建议尺寸为
640px x 1136px(iPhone
5),不同的设备也可以使用不同的尺寸。启动画面应该尽量简洁,以保证快速加载和用户体验。如果未指定该标签,则会显示默认的白色背景。

问题四:状态栏颜色是黑色,和主题不匹配

感谢泽泽社大佬提供的方案,可以修改第三步的html文件,头部加上以下代码,自己摸索设置代码中的颜色值,就可以修改状态栏颜色(已经确认最新几款苹果手机都兼容)

<meta name="theme-color" content="#1972F8" media="(prefers-color-scheme: light)">
<meta name="theme-color" content="#1C4D98" media="(prefers-color-scheme: dark)">

还有一种方式,就是直接申明状态栏颜色

<meta name="apple-mobile-web-app-status-bar-style" content="black">

black就是黑色

以上就是所有的解决教程,前两个问题其实网上都有,但是第三个是真的全网都搜索不到,我自己解密出来的。如果去淘宝封装价格都是好几百,甚至还有五百收徒的商品,简直太可怕了。不过经过了以上全部步骤之后,你的网站就可以免签打包成ios应用,给任何ios手机的人安装了。

当前页面是本站的「Baidu MIP」版。发表评论请点击:完整版 »