Demo - canvas实现设置、验证九宫格手势密码

报了360前端实习生的岗,除了测评、考试外还要作个大做业 25号考的技术综合的选择题简直让我开始怀疑人生哇 ╥﹏╥ 而后大做业我拿到的题目就是介个,实现手势密码的输入以及验证html

再次输入密码
设置密码
长度不够
验证密码

Demo演示地址前端

github传送门git

思路

graph TD
    A[根据原型图拆分布局]
    A --> | top-bar | B[顶部标题]
    A --> | canvas | C[手势绘制区域]
    A --> | Msg | D[提示信息]
    A --> | radio-group | E[单选按钮组]

顶部标题

在viewport完美视口下,固定div高度,宽度100%,文字居中则能完成适配~github

手势绘制区域

这里让绘制区域宽度去自适应,控制变量法嘛~canvas

  1. 设置默认属性。包括图形区域与屏幕的边距、圆半径、canvas高度(offsetX、offsetY、R、CanvasHeight)数组

  2. 动态获取窗口可见宽度做为canvas宽度,计算圆的间隔距离布局

  3. 根据上述参数计算九个点的原点位置spa

  4. 绘制九个圆点code

  5. 绑定touch三个事件并响应。绘制密码记录在LinePoint数组里htm

    1. touchstart 时判断当前触摸点和圆点的距离是否小于圆的半径,若是为真则记录当前圆点

    2. touchmove 一样判断触摸点与圆点距离,并在绘制过程当中根据记录数据绘制线条

    3. touchend 判断绘制密码是否符合规范,并根据单选框状态作出相应事件相应

提示信息

不一样状态下提示用户操做

单选按钮组

未选择任一按钮时,提示用户选择

  1. 设置密码

    1. 首次输入时,记录首次绘制密码

    2. 二次输入时,判断是否匹配首次绘制密码。若匹配,则存入localStorage或Cookie

  2. 验证密码

    1. 从localStorage或Cookie获取到密码,判断是否匹配

    2. 未获取到密码,输出提示

若中途变动单选按钮,重置临时存储的绘制密码及判断是否首次输入的状态,防止误操做可能出现的bug~

相关文章
相关标签/搜索