0%

readMe.md目录生成树形结构

1.通常我们在项目下有readme.md文件或者 .txt 文件,可以生成建立个项目树形结构,这个树形结构代表整个项目的结构,清晰明确的告诉别人项目的层级和指定资源,比如这个是我vue项目下的README.md文件

目录结构

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
├── .nuxt                       // nuxt发布的输出
├── build // Backpack发布的输出
├── src // 源代码
│   ├── assets // 主题 字体等静态资源(使用了scss,请参阅scss官方文档)
│   ├── components // 全局公用组件
│ │ ├── topBar // 页面顶部导航条
│ │ ├── tabBar // 全局tab切换条
│ │ ├── sendSms // 发送短信
│ │ ├── scroll // 滚动加载
│ │ ├── protocol // 公用协议模板
│ │ ├── payKeyBoard // 支付密码软键盘
│ │ ├── msg // 消息提示模块
│ │ ├── modal // modal对话框模块
│ │ ├── loading // 整站loading
│ │ ├── imgVcode // 图片验证码
│ │ ├── foot // 页面底部导航条
│ │ ├── btn // 整站按钮
│ │ ├── autofixedBottom // fixed + Input 调用键盘的时候fixed无效问题解决方案
│ │ └── swiper //轮播模块
│   ├── libs // 第三方、自定义插件
│   ├── store // 全局状态管理
│   ├── views // 视图
│   ├── App.vue // 入口页面
│   ├── api.js // 整站api都在这里
│   ├── filter.js // 全局过滤器
│   ├── directive.js // 全局指令
│   ├── router.js // 全局路由配置
│   ├── router-config.js // 页面路由
│   ├── main.js // 入口 加载组件 初始化等
│   ├── http.js // axios异步请求模块
│ └── http-config.js // 接口、活动工程地址相关
├── .babelrc // babel-loader 配置
├── .gitignore // git 忽略项
├── favicon.ico // favicon图标
├── index.html // 开发环境html模板
├── template.html // 测试与生产环境html模板
├── webpack.config.js // webpack配置相关
├── host.config.js // 配置环境域名文件
└── package.json // package.json

#.执行命令 cd : 项目文件夹下

  1. tree > README.md 此命令是最终形成这个 目录的重要命令`
  2. tree -l n (n代表是目录的指定层级为几)
  3. tree -I “node_modules” 过滤node_modules文件夹

#可能存在的bug问题:

1.比如cd到项目文件夹下执行 2 命令后在编辑器下打开乱码,解决乱码问题很简单,只需要打开此文件–另存为–然后编码选utf-8保存覆盖就完事了

最终生成项目文件树

稍微整理了几个经常在H5移动端开发遇到的东西

1. 弹出数字键盘

1
2
3
4
5
<!-- 有"#" "*"符号输入 -->
<input type="tel">

<!-- 纯数字 -->
<input pattern="\d*">

安卓IOS的表现形式应该不一样,大家可以自己试试。当运用了正则pattern后,就不用关注input的类型了😂

2. 调用系统的某些功能

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<!-- 拨号 -->
<a href="tel:10086">打电话给: 10086</a>

<!-- 发送短信 -->
<a href="sms:10086">发短信给: 10086</a>

<!-- 发送邮件 -->
<a href="mailto:839626987@qq.com">发邮件给:839626987@qq.com</a>

<!-- 选择照片或者拍摄照片 -->
<input type="file" accept="image/*">

<!-- 选择视频或者拍摄视频 -->
<input type="file" accept="video/*">

<!-- 多选 -->
<input type="file" multiple>

3. 打开原生应用

1
2
3
4
<a href="weixin://">打开微信</a>
<a href="alipays://">打开支付宝</a>
<a href="alipays://platformapi/startapp?saId=10000007">打开支付宝的扫一扫功能</a>
<a href="alipays://platformapi/startapp?appId=60000002">打开支付宝的蚂蚁森林</a>

这种方式叫做URL Scheme,是一种协议,一般用来访问APP或者APP中的某个功能/页面(如唤醒APP后打开指定页面或者使用某些功能)😒

URL Scheme的基本格式如下:

1
2
3
4
5
     行为(应用的某个功能/页面)    
|
scheme://[path][?query]
| |
应用标识 功能需要的参数

一般是由APP开发者自己定义,比如规定一些参数或者路径让其他开发者来访问,就像上面的例子🍤

注意事项:

  • 唤醒APP的条件是你的手机已经安装了该APP

  • 某些浏览器会禁用此协议,比如微信内部浏览器(除非开了白名单)

4. 解决active伪类失效

1
<body ontouchstart></body>

body注册一个空事件即可😂

5. 忽略自动识别

1
2
3
4
5
<!-- 忽略浏览器自动识别数字为电话号码 -->
<meta name="format-detection" content="telephone=no">

<!-- 忽略浏览器自动识别邮箱账号 -->
<meta name="format-detection" content="email=no">

当页面上的内容包含了手机号/邮箱等,会自动转换成可点击的链接😁

比如你有如下代码:

1
<p>13192733603</P>

但是有些浏览器会识别为手机,并且可以点击拨号😒

6. 解决input失焦后页面没有回弹

一般出现在IOS设备中的微信内部浏览器,出现的条件为:

  • 页面高度过小

  • 聚焦时,页面需要往上移动的时候

  • 所以一般input在页面上方或者顶部都不会出现无法回弹🤣

  • 解决办法为,在聚焦时,获取当前滚动条高度,然后失焦时,赋值之前获取的高度:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    <template>
    <input type="text" @focus="focus" @blur="blur">
    </template>

    <script>
    export default {
    data() {
    return {
    scrollTop: 0
    }
    },

    methods: {
    focus() {
    this.scrollTop = document.scrollingElement.scrollTop;
    },

    blur() {
    document.scrollingElement.scrollTo(0, this.scrollTop);
    }
    }
    }
    </script>

6. 禁止长按

以上行为可以总结成这几个(每个手机以及浏览器的表现形式不一样):长按图片保存长按选择文字长按链接/手机号/邮箱时呼出菜单

想要禁止这些浏览器的默认行为,可以使用以下CSS

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// 禁止长按图片保存
img {
-webkit-touch-callout: none;
pointer-events: none; // 像微信浏览器还是无法禁止,加上这行样式即可
}

// 禁止长按选择文字
div {
-webkit-user-select: none;
}

// 禁止长按呼出菜单
div {
-webkit-touch-callout: none;
}

7. 滑动不顺畅,粘手

一般出现在IOS设备中,自定义盒子使用了overflow: auto || scroll后出现的情况。

优化代码:

1
2
3
div {
-webkit-overflow-scrolling: touch;
}

8. 屏幕旋转为横屏时,字体大小会变

具体出现的情况不明😒,有时候有有时候没有,欢迎指出

优化代码

1
2
3
* {
-webkit-text-size-adjust: 100%;
}

9. 最简单的rem自适应

大家都知道,rem的值是根据根元素的字体大小相对计算的,但是我们每个设备的大小不一样,所以根元素的字体大小要动态设置😂

1
2
3
4
5
6
7
html {
font-size: calc(100vw / 3.75);
}

body {
font-size: .14rem;
}

效果如下:

像我一般的话,直接搞lib-flexiblepostcss-pxtorem就完事啦!

10. 滑动穿透

当你想在出现遮罩的时候,锁住用户的滚动行为,你可以这么做。

假设HTML结构如下:

1
2
3
<div class="mask">
<div class="content">我是弹框</div>
</div>

CSS样式如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
.mask {
position: fixed;
top: 0;
left: 0;
display: flex;
justify-content: center;
align-items: center;
width: 100%;
height: 100%;
background-color: rgba($color: #333, $alpha: .6);

.content {
padding: 20px;
background-color: #fff;
width: 300px;
}
}

效果如下:

可以看到,当在遮罩上滑动的时候,是会穿透到父节点的,最简单的办法就是阻住默认行为:

1
2
3
4
5
document.querySelector(".mask").addEventListener("touchmove", event => {
event.preventDefault({
passive: false
});
});

或者:

1
<div class="mask" @touchumove.self.prevent></div>

这样,当出现遮罩的时候用户的滑动就会被锁住啦👌