在之前的章节中,我们规定home.html 作为我们的主页。那么我们给其他人分享的平台地址应该是:你的ip:8000/home/
在我们之后的旅途中,会生产很多页面和功能。那么使用者如何返回主页呢?很多网站都用点击左上角的名字来返回主页,并且左侧菜单有隐藏和出现的按钮设置。毕竟总这么显着也有点挡害。
我的设想是增加一个按钮,贴在这个菜单右侧,点击一次就隐藏菜单,再点击就显示菜单。
所以让我们进入welcome.html中,想办法进行实现吧。打开welcome.html:
在菜单的html代码块下 新增一个button按钮,文案为“隐藏”
我们现在刷新页面仍然看不到这个按钮,那是因为这个按钮被菜单给遮挡了。我们发现这个菜单的宽度是固定的。所以我们也可以写死这个按钮的位置坐标:给button标签 增加css属性,所有css属性都是可以放在标签内的style属性中的,多个用;隔开。
margin-left的含义是外左边距,就是按钮距离浏览器左边界217px,217px是我量出的菜单宽度,各位可以自己多试试,找出一个最合适的距离。下面我们给它样式美化一些,让它看起来和这个菜单的一个风格。首先是背景色。要和菜单这个深蓝差不多,采用吸管可以直接吸取到屏幕上的任何颜色,然后点击chose确定。
新增的很多属性,大家有兴趣可以自己改一改看一看。字体颜色,圆角度。
刷新页面看看结果:
下面我们要给这个按钮 写一个id,方便我们后续用js来控制它:
然后再添加一个onclick属性,这个属性是告诉浏览器。按下这个按钮要执行哪个js函数用:
我们新建一个叫display_menu的js函数,作用是隐藏左侧菜单:
在button标签下,写一个script标签,内部作为我们js函数的存放位置。
然后新建我们的第一个js函数:display_menu()
就像python中写函数要加def 一样,js写函数要写function 函数名(入参){内容}
然后在这个函数中我们先 写元素定位。定位到我们的菜单方便我们后续操作菜单:定位的语句是 xxx = document.getElementById("填入元素的id")
其中的navbar 为我们菜单主体的id:
然后函数中的这个新建变量引用,menu就是我们的菜单的化身了,我们对它操作比如让菜单变颜色,隐藏,变大变小 都可以如意进行了。
新增一句让其隐藏的代码:menu.style.display = 'none';
这句的意思是 修改menu的style属性中的display属性。把其值改为none。display属性就是控制元素是否显示隐藏的属性,none就是隐藏,block就是显示。js代码均要以;分号结尾。
现在我们刷新页面,点一下隐藏按钮 看看效果吧:
的确隐藏了,但是这个按钮本身孤零零的放在这不太好看。那我们继续修改js的这个函数,让这个按钮本身移动到最左边,并且文案改成‘显示’
btn就是我们的这个控制按钮,点击后,把它的外左边距变成0px,就是紧贴左边,然后它的文案改成 ‘显示了’;让我们刷新页面再点击看看效果:
到这我们这个隐藏按钮就算制作完成了一半了。但是接下来,就要想,这个按钮现在的功能想变成 点击就显示菜单,然后把它的外左边距变成217px,文案再变成 ‘隐藏’。因为这个按钮只是一个啊,点击只是执行这个display_menu()函数。怎么弄呢?
我们要继续修改这个js函数,让其点击之前进行一个判断。如果此时按钮的文案是 隐藏,那么就去执行我们刚写好的隐藏的这一段,如果此时按钮的文案不是隐藏而是显示,那么就去执行新的一段让菜单显示的代码。所以这里我们需要学习js中的if分支语句了:
定位元素的语句因为 无论是否满足if条件 都需要先执行,所以移动到外部,可以少写点代码。下图中,把我们刚刚的操作元素的代码放在了符合执行的代码大括号内,判断条件:btn.innerText == '隐藏' 就是说按钮的文案如果是隐藏俩个字,那么就要隐藏菜单这套代码了
然后我们继续写显示菜单这套代码,放在else{}里:
现在我们刷新页面看看显示效果:
是不是可以完美的达到我们最初的设想了。
好,到目前为止,我们还可以做一个返回主页的按钮,让用户在任何页面都可以迅速返回到主页,那么具体放在哪里呢。我的习惯是避免左侧菜单来回显/隐影响,就放在右上角吧:
让我们在刚刚的script标签下面继续写一个button ,文案叫主页
然后给它的css属性加上:float,值为right
这样可以让这个按钮永远显示在父级(也就是body)内的最右侧
更改它的样式,让其好看一些:
font-size是文案大小,有多个值。
这里我们最好给添加一个标志图案 来给人直接回主页的感觉:
有俩种办法,一种是加入i标签,来添加图标。
另一种简单,直接去网上复制一个文案图标粘贴进来 颜色啥的随意:
给大家一个好网址:
小伙伴们可以自己设计一下这里,我只是介绍了方法,并不代表我的这个审美是最好的。
然后我们要介绍如何让这个按钮一点击就回到主页:
也就是点击跳转到:/home/
正常的方法我们是可以写一个a标签 超链接。但是现在我们做的是一个button标签的按钮,那么怎么操作呢?
结果就是我们用a标签把按钮给包裹起来即可:
此时点击这个按钮,就是会跳转到a标签的href的链接中了。让我们写href的值为/home/
好,现在大功告成,我们可以刷新页面点击试试看了,点击就是会跳转到这个首页了。因为我们今天所做的俩个按钮,都在welcome.html中。所以这俩个按钮会显示在任何子页面上,一劳永逸。