前端导航项目

之前在学习完JS,jQuery之后试着做了一个仿照谷歌的导航项目,一些基本的功能都可以实现。也可以进行扩展,打造出一个属于自己的专属导航界面。

【项目介绍】
项目名称 : 极速导航
具体功能 : 搜索、新增网站、删除网站、键盘导航

【技术栈】

  • jQuery
  • LocalStorage
  • SVG Symbols
  • 媒体查询
  • git & GitHub

【开发工具】

  • VS Code & WebStorm
  • Figma作图(一个在线作图网站)

【效果展示】



【效果链接】
由于我是部署到GitHub上面的,所以加载会有些慢,图片有时会不显示,不是bug,耐心等待几秒图片就出来了
https://lxy-dream.github.io/nav-2/dist/index.html

【代码链接】
https://github.com/lxy-dream/nav-2

【正文】

一、Figma作图

在开始做项目之前,需要把设计稿先做好,作图工具我采用的是Figma这个在线网站。当然,也可以采用PS进行作图。总之,在开始编写之前一定要有一个设计稿或者大致的轮廓才行。下面是我用Figma作图的地址链接,可以进行参考:

项目设计

二、创建文件

我使用VS Code来搭建项目文件,搭建之后的文件目录结构如下 :


(注:.cache文件夹、dist文件夹是用parcel命令行进行预览时候生成的文件,直接看src文件夹里面的内容即可)

三、写HTML和CSS

1、为了防止移动端页面被用户随意放大缩小,需要重写meta,可直接复制粘贴淘宝网页上面的meta。代码如下:

    <meta name="viewport"
        content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no,viewport-fit=cover">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
说明
  • 引入style.css文件
<link rel="stylesheet" href="style.css">
  • 生成网址前面的小图标
<link rel="shortcut icon" href="favicon.ico" type="image/x-icon" />

2、页面框架搭建
根据设计图纸进行搭建,最好采用语义化进行编写。由于使用了一些外部文件,所以需要引入。

说明

  • 引入main.js文件
 <script src="main.js"></script>
  • 引入icon图标
   <script src="//at.alicdn.com/t/font_1731808_u2qs0ecook.js"></script>
 <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>

3、写CSS
在给元素加样式的话需要特定情况特定分析,为了适合移动端,我采用了媒体查询这个功能进行响应。为了让我的页面画板不受其他元素的影响,我会先加入如下样式 :

* {
  box-sizing: border-box;
}
*:before,
*:after {
  box-sizing: border-box;
}
* {
  margin: 0;
  padding: 0;
}
扩展

1、给body加上背景色的话浏览器会智能的把它扩展到整个网页 )

2、图标可以使用iconfont,这用到了SVG Symbols,即阿里提供的一个矢量图标库。
步骤:

  • 进入网站找到需要的图标,加入购物车


  • 添加进项目里面


  • 选择Symobl,接着点击查看在线链接,复制生成的代码即可


  • 然后在html文件里面添加下面几行代码
    <style type="text/css">
        .icon {
            width: 1em;
            height: 1em;
            vertical-align: -0.15em;
            fill: currentColor;
            overflow: hidden;
        }
    </style>
  • 在需要添加图标的div里面添加下面代码:
 <svg class="icon">
                            <use xlink:href="#icon-add-pluss-"></use>
                        </svg>

四、功能实现

1、搜索功能
搜索是什么,是我发送一个请求,服务器接收我这个请求之后给我传递回来一个参数,可以利用form表单,包裹住input。来实现搜索功能。

2、新增功能
如何新增一个网站,简单流程就是弹出一个对话框,让用户输入网址,点击确认,在页面显示出来用户新增的网站书签。

  • 创建站点
$(".addButton").on("click", () => {
    let url = window.prompt("请问你要添加的网址是什么?");
    if (url.indexOf("http") !== 0) {
        url = "https://" + url;
    }
    console.log(url);
    hashMap.push({
        logo: simplifyUrl(url)[0].toUpperCase(),
        logoType: "text",
        url: url
    });
    render();
});
  • 构建哈希数组,用于留存添加的网站
const $siteList = $(".siteList");
const $lastLi = $siteList.find("li.last");
const x = localStorage.getItem("x");
const xObject = JSON.parse(x);
const hashMap = xObject || [{
        logo: "A",
        url: "https://www.acfun.cn"
    },
    {
        logo: "B",
        url: "http://www.bilibili.com"
    }
];
  • 新增网站显示在页面中
const render = () => {
    $siteList.find("li:not(.last)").remove();
    hashMap.forEach((node, index) => {
        const $li = $(`<li>
              <div class="site">
                  <div class="logo">${node.logo}</div>
                  <div class="link">${simplifyUrl(node.url)}</div>
                  <div class="close">
                  <svg class="icon">
                      <use xlink:href="#icon-close"></use>
                  </svg>
                  </div>
              </div>
      </li>`).insertBefore($lastLi);

3、键盘导航
只需要监听document元素就行了,代码如下 :

$(document).on("keypress", e => {
    const {
        key
    } = e;
    for (let i = 0; i < hashMap.length; i++) {
        if (hashMap[i].logo.toLowerCase() === key) {
            window.open(hashMap[i].url);
        }
    }
});

改进地方

1、由于书签小标是自动从网站获取的,所以会出现如果不是https开头com结尾的网站的话是生成不了小图标的。
2、通过键盘导航的话如果出现相同头字母的网址,无法区分,只能按照哪个在前打开哪个网页。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,002评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,777评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,341评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,085评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,110评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,868评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,528评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,422评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,938评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,067评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,199评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,877评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,540评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,079评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,192评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,514评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,190评论 2 357