一个小白来遇到的前端问题汇总

1. 写在前面

自从入了前端的坑,坑是越来越大,快把自己埋了。现在又开始搞样式了。

2. CSS样式的写法

CSS样式的写法有这么3种,下面我们一一介绍。

1. 外部样式表

链入外部样式表是这样的,一般放在<head></head>里:

<link href="mystyle.css" rel="stylesheet" type="text/css" media="all">…… </head>

其中mystyle.css是自己写的CSS文件,内部大概是长这样的:

.text-center{
    vertical-align: middle;
    text-align:center;
    display: table-cell;
}
.vw {
        width: 50%;
        height: 50%;
    }
.contentstyle{
        transform: scale(0.95);
        border-left-color:black;border-left-width:1px;border-left-style:solid;
        border-right-color:black;border-right-width:1px;border-right-style:solid;
        margin-top:-13px;
}

引入的时候,通过class来引入,像下面这样:

<div class="mybackgrounds"  id="maindiv">

2. 内部样式表

内部样式表大概长这样:

<head> …… <style type="text/css"> hr {color: sienna} p {margin-left: 20px} body {background-image: url("images/back40.gif")} </style> …… </head>

3. 内嵌样式

内嵌样式通常是这样子的:

<p style="color: sienna;margin-left: 20px;"> 这是一个段落 </p>

一般不推荐这第三种这种,一般使用第一种写法,容易管理,也便于重用。

不过这三种样式也是有优先级的:内联式 > 嵌入式 > 外部式,但是嵌入式>外部式有一个前提:嵌入式css样式的位置一定在外部式的后面。

其实总结来说,就是–就近原则(离被设置元素越近优先级别越高)。

3. CSS样式表和Js文件位置

一般来讲引用的外部js放在下面,外部css放在上面这是习惯,其原因如下:

1. JS 有可能会修改 DOM.

典型的,可能会有 document.write. 这意味着,在当前 JS 加载和执行完成前,后续所有资源的下载有可能是没必要的。这是 JS 阻塞后续资源下载的根本原因。

2. JS 的执行有可能依赖最新样式。

比如,可能会有 var width = $(‘#id’).width(). 这意味着,JS 代码在执行前,浏览器必须保证在此 JS 之前的所有 css(无论外链还是内嵌)都已下载和解析完成。这是 CSS 阻塞后续 JS 执行的根本原因。

3. CSS要先渲染。

CSS放在前端是页面渲染时首先是根据DOM结构生成一个DOM树然后加上CSS样式生成一个渲染树,如果CSS放在后面可能页面会出现闪跳的感觉,或者是白屏或者布局混乱样式很丑直到CSS加载完成。

但是,现代浏览器之间的竞争也十分激烈,他们通常有自己的优化方式,能够进行prefetch优化,这样的话,性能是如此重要,现代浏览器在竞争中,在 UI update 线程之外,还会开启另一个线程,对后续 JS 和 CSS 提前下载(注意,仅提前下载,并不执行)。有了 prefetch 优化,这意味着,在不存在任何阻塞的情况下,理论上 JS 和 CSS 的下载时机都非常优先,和位置无关。

4. iframe与变换缩放

使用iframe的时候,最大的好处就是内网页不用自己写了,可以引用,但是通常会有一个问题,因为iframe有可能只是我们自己网页的一部分,那么引用网页有可能是一个完整的网页,那么这样子的话,会造成显示上的问题。那这时候,其实使用缩放来做,可以做一个折中的方案,毕竟原网页不是你想改就能改的。

缩放也是有2种的,一种是ZOOM,另一种是CSS3的transform:scale,那么他们有什么不同呢?

  1. 首先,他们的来源不同:

    还在几年前,zoom还只是IE浏览器自己私有的玩具,但是,现在,除了FireFox浏览器,其他,尤其Chrome和移动端浏览器已经很好支持zoom属性了,注意,虽然Chrome/Safari浏览器支持了zoom属性,但是,其实zoom并不是标准属性。

    而Transform则是CSS3标准,明明确确写入规范的。从IE9+到其他现代浏览器都支持。

  2. 其次,是他们写法不同:

    来看一下他们如果都是缩放一半,应该怎么写:

    .zoom-half { zoom: 0.5; }

    .scale-half { transform: scale(0.5); }

  3. 最后是他们的效果不同:

    zoom缩放是相对于左上角的,而scale默认是相对于元素的中心点缩放的,scale可以通过设置transform-origin来改变缩放的相对位置,当设置transform-origin: 0 0时,scale缩放可以达到和zoom缩放相似的结果。

总而言之还是有一些差异的:

  1. 浏览器兼容性。IE全族/Chrome/Safari和IE9+现代浏览器的差别。
  2. 控制缩放的值不一样。zoom更全面,但是不能是负数,只能等比例控制;而scale虽然只能是数值,但是能负数,可以只控制1个维度。
  3. zoom的缩放是相对于左上角的;而scale默认是居中缩放;
  4. zoom的缩放改变了元素占据的空间大小;而scale的缩放占据的原始尺寸不变,页面布局不会发生变化;
  5. zoom和scale对元素的渲染计算方法可能有差异。
  6. 对文字的缩放规则不一致。zoom缩放依然受限于最小12像素中文大小限制;而scale就是纯粹的对图形进行比例控制,文字50%原来尺寸。
  7. 渲染的性能差异明显。

综合上述原因,iframe应当使用的是transform:scale放缩更好一些。

5.背景渐变

背景渐变这个应该简单的不能再简单了,简单来讲就是长这样的:

.mybackgrounds{
    background:-webkit-linear-gradient(top,#222222,#FFFFFF);
}

这里具体的,来讲,background是设置背景,而-webkit-linear-gradient则表示线性渐变,(top,#222222,#FFFFFF)分别表示的是开始位置(从上到下),开始颜色(灰黑),结束颜色(白色)。更具体的可以看一下下面这里:背景渐变详解

6. 输入框组

输入框组就像之前提到的那样,boostrap里提供了一个简单的样式,但是还算美观。具体的写法如下:

<div  class="form-group">
    <div class="input-group ">
        <span id="hotwordspan" class="input-group-addon">
        热点词汇
        </span>
        <asp:TextBox ID="TextBox2"  class="form-control"runat="server">
        </asp:TextBox>
    </div>
</div>

尤为值得注意的是,class="form-control"输入框的这个class要添加,不然的话,输入框会比前一个span小上一部分,因此必须加上这个。

同样的,<asp:TextBox ID="TextBox2" class="form-control"runat="server"></asp:TextBox>

这个可以换成其他的组件,包括像下拉框、选择框、输入框等等都可以。

7. 时间选择

时间框也是非常常见的组件,我们来看一下长什么样:

<div class="form-group">
    <div class="input-group date form_date" data-date="" data-date-format="dd MM yyyy" data-link-field="dtp_input2" data-link-format="yyyy-mm-dd">
    <span class="input-group-addon">选择日期</span>
    <!--这是最终获取日期的框-->
    <asp:TextBox ID="TextBox1" class="form-control" runat="server"></asp:TextBox>
    <!--这是一个清除图标-->
    <span class="input-group-addon"><span class="glyphicon glyphicon-remove"></span></span>
    <!--这是一个日期图标-->
    <span class="input-group-addon"><span class="glyphicon glyphicon-calendar"></span></span>
    </div>
    <!--这是一个展示日历框-->
    <input type="hidden" id="dtp_input1" value="" />
</div>

这都写完了就完成了么?不,这个组件被称为是Js组件,因此还需要写以下js代码:

 $(‘.form_date‘).datetimepicker({
                format: ‘yyyy-mm-dd‘,
                weekStart: 1,
                autoclose: true,
                startView: 2,
                minView: 2,
                forceParse: false,
                //选择语言
                language: ‘zh-CN‘,
                //今天按钮可用否
                todayBtn: true,
                //今天高亮否
                todayHighlight: true,
                //初始化日期
                initialDate: ‘2016-07-01‘,
            });

当然,把这些都写完了以后,还是不成功的话,你需要考虑以下有没有引入这个:

    <link href="css/bootstrap.min.css" rel="stylesheet" />
    <link href="css/bootstrap-datetimepicker.min.css" rel="stylesheet" media="screen" />

上一个是Bootstrap样式,下一个是datetimepicker组件。

时间: 2024-08-28 14:00:58

一个小白来遇到的前端问题汇总的相关文章

最热web前端技术汇总

Web前段技术发展很快,主流技术日新月异,想想自己刚毕业那会用的asp技术,现在已经很少有主流网站在使用了. 再到后来的J2EE框架,然后SpringMVC大行其道,但是最近各种js框架被广为传播,Html5的推出很是丰富了移动互联网的发展,此文对当前最新的几种web前端技术进行的汇总,让大家更多地了解,然后取其所长,避其所短,快速推出简约大方,维护方便,性能良好的个人网站. JavaScript MV*框架 在相当长的一段时间里,每个程序员都要学会如何利用JavaScript来编写弹出一个警告

一个小白的html学习

这将是我的第一篇博客,只是想记录一下这段时间自己学习html的过程和感受! 和很多人可能一样,我接触html的时候,也是一点都不熟悉,虽然大学的时候接触了PHP设计,但毕竟是作为一门选修课,教的和学的都不是很多,所以说,自己在这门领域,其实也就是一个小白.因为很明白自己是一个小白的身份进入到这个领域的,所以一开始就告诉自己要付出更多的努力去学好! html5到底是一个什么东西呢?很多人接触的时候都会问这样一句话,其实html我的理解就是一门简单的网页语言,至少说是我这段时间学的是比较基础的东西,

【同行说技术】Android程序员从小白到大神必读资料汇总(四)

在文章<Android程序员从小白到大神必读资料汇总(一)和(三)>里面介绍了基础学习资料和一点点的进阶资料,今天小编收集了5篇带有实例干货的资料,赶紧来看看吧!另外,喜欢写博客的博主可以申请加工程师博主交流群:391519124,分享你的博文,和大牛们一起交流技术 ~ 一.Android 内存泄漏总结 内存管理的目的就是让我们在开发中怎么有效的避免我们的应用出现内存泄漏的问题,本篇详细总结了如何防止内存泄露,满满的干货 二.理解Android安全机制 从Android系统架构着手,分析And

我是一个小白

我是一只小白,心中有所怀揣,虽然现在步履蹒跚,但是丝毫不影响我对JS的满心期待.我是一只小白,复杂难题自然无奈,简单疑问也会塞满我的脑袋,但我依旧努力追寻答案.我是一只小白,心知止步就会淘汰,故或无敌勤奋或无敌慵懒,我会迎来我的精彩!我是一只小白,很多问题偶都不明白,谁来告诉我答案,是我太菜,还是JS的高峰实在难攀,谁来给我指南,明明href可以很简单,为何啰哩吧嗦像个老太太,我是一个小白,想不明白想不明白!

【同行说技术】Android从小白到大神必读资料汇总(二)

在文章<Android程序员从小白到大神必读资料汇总(一)>里面介绍了几篇Android入门和提升效率的技术资料,今天小编收集了5篇进阶的资料,赶紧来看看吧!另外,欢迎大家加入工程师博主交流群:391519124,交流博客经验和技术 一.Android开发相见恨晚的方法和接口 Android开发中,有哪些让你觉得相见恨晚的方法.类或接口? 二.Android 多渠道打包原理和使用 学会安卓 APP 多渠道打包的技巧,让你的APP开发更高效 三.Google Java Style:Google的

【同行说技术】iOS程序员从小白到大神必读资料汇总

在文章<iOS程序员从小白到大神必读资料汇总(一)>里面介绍了很多iOS入门学习的资料,今天小编就发几篇技术进阶的文章,快来看看吧! 一.iOS后台模式开发指南 这个教程会教你在什么时候怎么去用最常用的一些后台操作 二.iOS核心高级动画技巧 这是一篇在github上很受欢迎的对iOS开发高级动画技巧的翻译文,非常值得学习 三.iOS开发总结之代码规范 这篇文章整理了比较好的代码规范,对程序员的代码风格的塑造很有帮助! 四.Top 100 的 iOS app 都用到了哪些库 文章作者分析了美国

一个小白走进了前端大门

大三上学期放假,心里就一直焦虑,马上大四了,在学校都玩两年半了,一点都没学习,快毕业了,该干点啥啊?学的采矿专业,现在煤炭行业很不景气,再一个根本不想干这行. 想来想去,先学修电脑吧,以后在小区附近开个电脑维修店(在学校经常给同学修电脑),学了学了几天之后,一次偶然和半年不联系的哥们聊天,他问我:干啥呢大哥?我说我在学修电脑,他说修电脑多没技术含量,现在web前端挺好,入门也快,待遇也高,于是我就接触了前端. 学的第一天,感觉css好难,不懂是啥,于是在贴吧加了个吧友,要了qq,第二天我问他一个

对于一个小白来说,遇到的前端问题(2)

1. 写在前面 自从入了前端的坑.坑是越来越大,快把自己埋了.如今又開始搞样式了. 2. CSS样式的写法 CSS样式的写法有这么3种,以下我们一一介绍. 1. 外部样式表 链入外部样式表是这种,一般放在<head></head>里: <link href="mystyle.css" rel="stylesheet" type="text/css" media="all">-- </h

前端资源汇总[转载]

JavaScript 框架/库 Animations vivus:可以动态描绘 SVG 的 JS 库, 支持多种动画 Web Animation:Javascript 实现的 Web Animation API scrollReveal.js:使元素以非常酷帅的方式进入画布 (Viewpoint) snabbt.js:一个利用 Javascript 和 CSS transform 的 animation 库 matter-js:2D 物理效果引擎,碰撞.弹跳等 parallax:一个用于响应智能