精华内容
下载资源
问答
  • 04709 [电信行业]中国移动互联网代理商培训手册-业务篇(DOC 82页).doc
  • 新快网络代理商合作协议范本怎么写呢,小编为大家带来了一份最新新快网络代理商合作协议范本,能够帮助大...该文档为新快网络代理商合作协议范本,是一份很不错的参考资料,具有较高参考价值,感兴趣的可以下载看看
  • 代理商分销合同

    2019-04-12 10:49:01
    代理商分销合同 甲方:_______________________ 乙方:_______________________ 甲、乙双方本着平等互利、共同发展的原则,经友好协商,就乙方作为甲方VOIP语音网关系列产品的代理销售事宜,达成以下协议。双方均...
  • VS 网络代理商手册.doc

    2020-11-01 10:31:52
    VS 网络代理商手册 VS 网络代理商手册 众智网络科技有限公司 众智网络科技有限公司 PAGE 30 众智网络科技有限公司 众智网络科技有限公司 PAGE 1 目 录 TOC \o "1-3" \h \z \u 第一章 序言 2 第二章 公司简介 3 第三...
  • 文档名称 百度 KA 代理商手册 2014 阅读单位 百度 KA 分销商大客户销售部 发布日期 2014 年 3 月 拟定单位 百度 KA 渠道 百度KA 代理商手册 前言 百度Nasdaq 简称BIDU 是全球最大的中文搜索引擎致力于向人们提 供...
  • NetSuite CRM系统优势及中国代理商 随着传统的CRM模式的发展云计算CRM早已在行业内掀起热潮它正以一种全新的运行模式为企业管理家们带来全新的管理思路与应用体验NetSuite公司推出的NetSuite CRM便是这样一种在线...
  • Add: 上海市呼玛路547号4楼 Tel:021-60832332 Fax:021-60832330 Zip:200431 上海兆民云计算科技有限公司 兆民云计算代理商合同 客户编号 合同编号 日 期 兆民云计算代理商合同 甲方代理人 以下简称甲方 地址
  • 研发体系 转正答辩报告 研发体系 转正答辩报告 1 研发体系 转正答辩报告 用友软件>幸福企业 用友软件>幸福企业 天翼ERP价保系统介绍 代理商 用友软件股份有限公司 操作内容介绍 业务流程介绍 1 2 操作手册 3
  • 该模型是从广告代理商的角度出发的,该代理商希望在缺少或存在广告商可以用来获得地理征服服务的外部选项的情况下,从两种广告服务中获得的收益最大化。 一个关键的结果是,有时代理商不提供地理搜索服务而受益,...
  • 代理商培训手册 业务篇 目 录 一 前言 二 市场人员培训流程 三 前期准备 四 素养篇 销售的定义 成功销售员必备的十大素质 成功销售员必备的十大心态 市场销售的团队精神 市场人员需要注意的几个要点 市场人员的...
  • 编号 _ 互联网电视系统代理合同 甲 方 _ 乙 方 _ ...运营市场共同的发展 因此双方本着自愿 公平诚实信用的原则及互利互惠 共同发展的目的 经友好协商达成互联网电视系统代理合同 为明确双方的权利义务和责任签订本合
  • 越来越多的人都想分一杯物联网的羹,尤其是物联卡行业,物联卡是由三大运营给企业设备提供的2G/3G/4G流量卡,在物联网市场的价值越来越明显,因此,市场上出现了许多咨询物联网卡代理的朋友,那么物联卡如何代理呢...

        近年来随着物联网行业的爆发,越来越多的人都想分一杯物联网的羹,尤其是物联卡行业,物联卡是由三大运营商给企业设备提供的2G/3G/4G流量卡,在物联网市场的价值越来越明显,因此,市场上出现了许多咨询物联网卡代理的朋友,那么物联卡如何代理呢,接下来,物联卡中心小编为大家简单介绍一下:
        为什么现在物联卡那么火?
        物联网已经渗透到人类生活的方方面面,物联网卡的应用带给人们多种便利,例如,我们生活中比较常见的智能监控和监测、医疗健康、车联网、智能穿戴、智能家居、无线POS机等诸多领域,正是运用了物联卡技术,让手机等智能终端连网,进行信息的收集、存储、传输,从而实现人与物、物与物之间的互联,而且在现在移动互联网时代,万物互联对我们越来越重要。
        三大运营商物联卡可以提供以下功能:
        ①基础通信能力:GPRS通信能力和短信通信能力,短信可提供不同优先级服务(重发频次、储存时间),充分满足不同集团客户需求,通过专用网元设备支持包括短信、无线数据及语音等基础通信服务,提供用户自主的通信连接管理和终端管理等智能连接服务。
        ②终端状态查询:向客户提供开关机信息、终端位置信息、终端GPRS上线、离线、IP、APN等信息查询。
        ③账务信息查询:向客户提供账户信息查询,提供账户欠费、流量超标等事件的提醒功能。
        ④业务统计分析:向用户提供多维度的业务报表统计及分析等。
        ⑤灵活计费功能:根据客户需求提供流量池、生命周期等多种计费方式。
        物联卡怎么代理?
        物联卡如何代理?物联卡想要做代理找认证?对于代理,小编建议可以找三大运营商办理物联网卡,不过,这种一般要求办理的数量较大,也可以联系物联卡渠道,目前物联网卡运营商蛮多的,建议从物联网卡的材质方面、物联网卡的收费方面、物联网卡售后服务方面,综合衡量,货比三家。

    展开全文
  • UNIX操作系统被认为是完整的OS,因为一切都来自一个供应。 安全与防火墙 Linux随附了基于Netfilter和IPTables的开源防火墙工具,可保护您的服务器和台式机免受黑客和黑客的攻击。UNIX操作系统带有自己的...

    Linux初学者面试问题

    Linux基本面试问题

    1.什么是Linux?

    回答: Linux是基于Linux内核的操作系统。它是一个开源操作系统,可以在不同的硬件平台上运行。它为用户提供了免费的低成本操作系统。这是一个用户友好的环境,他们可以在其中轻松修改和创建源代码的变体。

    2.谁发明了Linux?解释Linux的历史?

    回答:  Linus Torvalds创建了Linux。莱纳斯·托瓦尔兹(Linus Torvalds)于1991年在芬兰赫尔辛基大学(University of Helsinki)求学。他开始自行编写代码以免费获得Unix的学术版本。后来,它作为Linux Kernel变得流行。

    3. Linux和Unix有什么区别?

    回答: Linux与Unix

    LinuxUnix系统
    提供付费和免费分发。不同级别的Unix使用不同的付费结构。
    Linux主要使用带有可选命令行界面的GUIUnix使用命令行界面
    Linux OS是便携式的,可以在不同的硬盘中执行Unix OS不可移植。
    Linux由全球Linux社区开发。Unix由AT&T开发人员开发。
    Linux是免费的。它是在GNU许可下通过互联网下载的。大多数类似Unix的操作系统不是免费的。
    Linux用于家用PC,电话等。Unix用于服务器系统。

    和其他一些区别。

    Linux是Unix的克隆版本。但是,如果考虑可移植操作系统接口(POSIX)标准,则可以将Linux视为UNIX。

    • Linux只是核心

    所有Linux发行版都包括GUI系统,GNU实用程序,安装和管理工具,GNU c / c ++编译器,编辑器(vi)以及各种应用程序,例如OpenOffice,Firefox。

    UNIX操作系统被认为是完整的OS,因为一切都来自一个供应商。

    • 安全与防火墙

    Linux随附了基于Netfilter和IPTables的开源防火墙工具,可保护您的服务器和台式机免受黑客和黑客的攻击。UNIX操作系统带有自己的防火墙产品。 

    • 备份与恢复

    UNIX和Linux带有自己的一套工具,用于将数据备份到磁带和其他备份介质。但是,Linux和UNIX共享一些通用工具,例如tar,转储/还原和cpio等。

    4. Linux操作系统的核心是什么?

    回答:内核是Linux操作系统的核心。

    5.什么是Linux内核?

    回答:内核是操作系统的心脏。它充当软件和硬件之间的桥梁。如果软件请求硬件,则内核将在软件和硬件之间传递数据。例如,如果您想播放一首歌曲,则应启动默认播放器,它会请求内核播放一首歌曲,现在,内核将与硬件联系以寻求许可或寻求硬件组件,就像您插入任何耳机一样。装置。大多数Android手机使用Linux内核。 

    是的,内核可以编辑,因为它是根据通用公共许可证发行的。

    6.什么是BASH?

    回答:  Bash是Brian Fox为GNU项目编写的Unix shell和命令处理器。它是免费软件,可以代替Bourne Shell。这是一个解释后的未编译过程,也可以在终端窗口中运行。这使用户可以编写命令并引起动作。Bash能够从Shell脚本读取命令。

    7.什么是LILO?

    回答:  LILO表示Linux Loader是用于Linux操作系统的引导加载程序。大多数Linux操作系统使用LILO将操作系统引导到主内存中以启动操作。

    8.什么是CLI?

    回答:  CLI表示命令语言解释器。它与计算机程序进行交互,用户在其中以文本行的形式发出命令。它也与计算机终端交互,该界面接受文本行并将其作为命令转换为操作系统。 

    9.  开源的优势是什么?

    回答:   Linux是最早的开源技术之一,许多程序员添加了对用户完全开放的软件,这意味着您可以下载文件并随意更改代码。它为用户提供了多种选择,并提高了安全性。

    10.开源的缺点是什么?

    回答: 下面提到的开源操作系统的缺点

    1. 使用困难 
    2. 相容性问题
    3. 责任与保证
    4. 隐藏费用

    11.什么是Shell

    回答:  Shell是一个计算机程序,充当用户和内核之间的接口。用户可以通过在Shell上编写程序,命令和脚本来与内核进行通信。它接受人类可读的命令,并将其转换为内核可理解的语言。

    12. Linux中有几种类型的Shell? 

    回答:它们是Linux中的五个Shell:

    • C Shell(csh):类似于C语法,并提供拼写检查和作业控制。
    • Korn Shell(ksh):是一种高级编程语言Shell。
    • Z Shell(Zsh):它提供了一些独特的性质,例如观察登录/注销监视,文件名生成,启动文件,结束注释。 
    • Bourne Again Shell(bash):这是Linux发行版的默认设置。
    • 友好的交互式Shell(Fish):它提供基于Web的配置,自动建议等。 

    13. Linux的基本组件是什么?

    回答:   Linux的基本组件

    1. 内核:它是Linux的核心组件,它充当软件和硬件之间的接口。  
    2. Shell:它充当用户和内核之间的接口。
    3. GUI:   它代表图形用户界面,这是用户与系统交互的另一种方式。但这与图像,按钮,用于交互的文本框不同。
    4. 系统实用程序:这些是允许用户管理计算机的软件功能。
    5. 应用程序:旨在执行一组任务的一组功能。

    14.发出命令时如何打开命令提示符?

    回答:通过按CTRL + ALT + T或在菜单搜索栏中提供终端来启动终端。

    15.什么是交换空间?

    回答:当物理Ram内存用完时,将使用交换空间。它将Ram非活动页面移动到交换空间。它可以以专用交换分区或交换文件的形式考虑。

    16.什么是GUI?

    回答: GUI表示图形用户界面。它是一种人机界面,使用可以通过鼠标操作的窗口,图像,图标和菜单。电子产品中的大多数现代应用程序都通过GUI与用户通信。GUI是使用按钮,菜单,消息框等的图形和文本交互的组合。

    17.解释Linux中的文件权限类型?

    回答:每个文件或目录都具有3个权限

    他们是 

    1. Read--它是指只有他们可以读取该文件。
    2. Write--这是指他们可以写入文件或修改目录的文件。
    3. Execute--影响用户执行文件或查看目录文件的能力。 

    18.环境变量是什么?

    回答:它们是动态值,会影响计算机上程序的过程。它们存在于每个操作系统中,并且它们的类型可能有所不同。可以创建,编辑,保存和删除它们,还可以提供有关系统行为的信息。

    20.什么是符号链接? 

    回答:它将使用其路径重定向到另一个文件。目标文件不包含任何数据。符号链接重定向到文件系统中某个位置的另一个条目。如果删除了目标文件,则将删除指向该文件的链接,但不会删除该文件。

    21.什么是硬链接?

    回答:硬链接是Linux上现有文件的另一个名称。我们可以为任何文件创建如此多的硬链接。他们可以为其他硬链接创建链接。

    22.什么是重定向?

    回答:重定向可以定义为更改标准输入和输出设备。要使用重定向元字符,您可以重定向文件或程序。 

    23.什么是守护程序?

    回答:守护程序是一个后台进程,它接受来自其他计算机的服务请求,大多数操作系统使用其他形式的守护程序。  

    24.描述根帐户?

    回答: Root是用户名,默认情况下可以访问所有文件和命令。超级用户可以执行许多操作,但是普通用户不能执行诸如安装软件,更改文件权限等操作。

    25.解释虚拟桌面吗?

    回答:当您面临如何管理桌面上的多个窗口的问题时,虚拟桌面是一种用户界面,虚拟桌面可以作为替代方法。虚拟桌面存储远程服务器,并允许您在干净的状态上使用一个或多个程序。 

    26.使用vi编辑器时有哪些不同的模式?

    回答: vi编辑器中有三种模式。他们是 

    • 命令模式/常规模式
    • 插入模式/编辑模式。
    • 防爆模式/更换模式。 

    27.什么是inode和进程ID?

    回答: inode是赋予每个文件的唯一名称,进程id是赋予每个进程的唯一名称。 

    28. Linux中的进程状态是什么?

    回答:  Linux中的五个过程状态。他们是

    1. 新建/就绪:已创建一个新进程并准备运行。
    2. 正在运行:正在执行该进程。
    3. 阻止/等待:进程正在等待用户输入。 
    4. 终止/完成:进程已完成执行或被操作系统终止。 
    5. 僵尸:进程已删除,但仍在进程表中存在有关该进程的信息。

    Linux进程状态

    29.解释Linux中的流程管理系统调用吗?

    回答:  Linux中的流程管理系统调用:

    • fork():用于创建新进程。
    • exec():执行新进程。
    • wait():等到进程执行。
    • exit():退出进程。

    系统调用以获取进程ID:

    • getpid():查找唯一的进程ID。 
    • getppid():查找唯一的父进程ID。 

    30.解释Linux中的文件权限组?

    回答: 每个文件和目录都有三个基于用户的权限组。

    他们是:

    1. 所有者:所有者只需要访问文件或目录,就不会影响其他用户的操作。
    2. 组:这些权限仅适用于已分配给文件或目录的组。它们不会影响其他用户的操作。
    3. 所有用户:这些权限适用于系统上的所有用户。

    31.什么是Linux中的文件系统?

    回答: Linux文件系统存储和处理数据。没有文件系统,它将无法知道文件的起始位置和文件的结束位置。

    32.解释Linux中不同的文件系统类型吗?

     

    订阅我们的YouTube频道以获取新的更新。

     
     

    回答:在Linux中,有许多文件系统:

    Ext,Ext2,Ext3,Ext4,JFS,XFS,btrfs,ufs,autofs,devpts,ntfs和交换。

    Linux初学者教程

    Linux管理员面试问题

    32.为什么需要LVM?

    回答: LVM代表大容量管理,它是一种存储管理设备。用户可以创建,调整大小和删除LVM分区。它增加了抽象性,灵活性和控制性。LVM用于将现有存储设备收集到该组中并分配逻辑单元。 

    33.什么是umask?

    回答: unmask代表用户文件创建模式。用户创建任何文件时,它具有默认文件权限。因此,取消屏蔽将对新创建的文件指定很少的限制(它控制文件权限)。

    1个
    umask [-S] [mask]

    34.如何为用户永久设置面罩? 

    回答:如果调用unmask命令时不带任何参数,则表示它将显示当前掩码。 

    要永久设置取消遮罩,我们有两种类型。

    他们是:

    • Ocotal表示。
    • 符号表示。

    35.在Linux中什么是网络绑定?

    回答: 网络绑定是将两个以上的网络接口组合成一个网络接口的过程。它通过增加网络吞吐量和带宽来提供性能改进和冗余。无需担心一个接口关闭或拔出,因为另一个接口可以工作。绑定界面的行为取决于绑定方法。 

    36. Linux中的网络绑定有哪些不同的模式?

    答: 

    • Mode-0(balance-rr):这是默认模式,基于轮询策略。它提供容错和负载平衡功能。它使用轮询方式来传输数据包。
    • 模式1(active-backup):它基于主动备份策略,只有一个从机将在频带中起作用,而另一个将在其他从机发生故障时起作用。它还提供了容错能力。
    • 模式2(balance-xor):设置源Mac地址和目标Mac地址之间的异或模式,以提供容错能力。
    • 模式3(broadcast):它基于广播策略,并在从属接口中传输所有内容。它还提供了容错能力,并且只能用于特定目的。
    • 模式4(802.3ad):这是一种动态聚合模式,它创建了具有相同速度的聚合组。它使用传输哈希方法选择从站以进行传出流量。
    • 模式5(balance-tlb):传出流量是根据从站上的当前负载,而传入流量是从站接收的。这称为自适应发送负载平衡模式。 
    • 模式6(balance-alb):这是一种自适应负载平衡模式。它不需要任何开关支持。 

    37.如何查看默认路由和路由表?

    回答:   要显示默认路由和路由表,我们使用以下命令。

    1个
    2
    3
    4
    5
    $ route-n
     
    $ nestat-rn
     
    $ ip

    38.如何检查Linux服务器中正在侦听哪些端口?

    回答:我们有两个命令来检查Linux Server中正在侦听哪些端口。以下是两个命令 

    1个
    2
    # netstat --listen
    # netstat -l

    39.内核模块位于何处?

    回答: lib / modules / kernel-version /,此目录存储有关Linux系统下已编译驱动器的所有信息。使用lsmod命令,我们还可以看到已安装的内核模块。 

    40.如何在Linux中更改默认运行级别?

    回答:要更改Linux中的默认运行级别,请使用init命令。 

    41.如何使用nfs共享目录?

    回答:   要使用NFS共享目录,请首先编辑配置文件和'/ etc / exports'并添加目录名称' /'。现在,重新启动NFS服务。

    42. SMTP,DNS,FTP,DHCP,SSH和Squid使用的默认端口是什么?

    Ans。 详情如下

    服务端口
    SMTP25
    DNS53
    FTP20(Data Transfer) 21(Connections Established)
    DHCP68(dhcp client), 67(DHCP server)
    SSH22
    Squid3128

    43.如何在Linux中锁定用户帐户?

    回答:为了安全起见,已完成锁定用户帐户的操作,以便未经授权的用户无法登录。因此,我们有几种方法可以锁定用户帐户。其中一些在下面。 

    1. 使用passwd命令锁定或禁用密码。
    2. 使用usermod命令或chage命令使用户帐户过期。
    3. 使用nologin命令(/ sbin / nologin)更改外壳。

    Linux命令面试问题

    44.什么是ls命令及其作用?

    回答:这是Linux中的基本命令之一。它用于列出文件系统中的所有文件和目录。zom

    句法: 

    <span style =“ color:#ecf0f1; background-color:#000000;”> ls [OPTIONS] [FILES] </ span>

    我们可以在不传递参数的情况下使用它,然后它将列出当前工作目录中的所有文件。文件将按字母顺序显示。 

    <span style =“ background-color:#000000; color:#ecf0f1;”>是</ span>

    要列出特定目录文件,请在语法中使用目录名称,请按照以下语法中的说明进行操作。

    ls / etc
    我们还可以使用语法传递多个目录名称,但以空格分隔。 

    ls / etc / var / etc / passwd

     45.在Linux中,tail命令是什么?

    回答: Tail命令打印给定数据的最后N行,默认情况下它打印10行。 

    句法: 

    尾部[OPTION] ... [FILE]

    例: 

    $ cat names.txt

    Tableau <br> SQL Server <br> Linux管理<br>现在,在不提供任何选项或输入的情况下检查语法。

    $ tail state.txt

    <span style =“ font-family:'courier new',courier,monospace;”> <span style =“ color:#222222; font-family:Verdana;”> <span style =“ white-space:pre-wrap ;“> <strong> <em>输出:</ em> </ strong> <br> </ span> </ span> </ span> Tableau <br> sql server <br> linux管理<span style =” font-family:'courier new',courier,monospace;“> <span style =” color:#222222; font-family:Verdana;“> <span style =” white-space:pre-wrap;“> <br > </ span> </ span> </ span>

    46. Linux中的grep命令是什么?

    回答: grep命令是一个过滤器,用于全局搜索正则表达式。

    句法:

    grep [选项]模式[文件]

    47. Linux中的ps命令是什么? 

    回答: ps命令显示系统的当前进程状态。并显示进程ID和其他一些相关数据。 

     

    句法: 

    Ps [选项]

    输出:

    1个
    2
    3
    4
    5
    6
    7
    [root@rhe17~]# ps
     
    PID TTY    TIME CMD
     
    12330 pts/0  00:00:00 bash
     
    21621 pts/0  00:00:00 ps

    如:ps -ef|grep tomcat (查询tomcat进程)

    48. Linux中的env命令是什么?

    回答: env是一个shell命令,用于打印当前环境变量的列表,它可以在另一个环境中运行另一个进程,而无需对当前环境进行任何修改。 

    1个
    env [OPTION]... [-] [NAME=VALUE]... [COMMAND [ARG]...]

    选件

    标签描述
    -i,-ignore-environment从一个空的环境开始。
    -0,--null输出行以0(空)字节而不是换行符结尾。
    -u,--unset = NAME从环境中删除变量NAME
    --help显示帮助消息并退出。

    49.什么是Linux中的top命令?

    回答:用于显示系统进程的top命令,它显示并更新排序的进程信息。 

    50. Linux中的netstat命令是什么?

    回答: netstat命令提供有关网络和路由表,接口静态信息以及有关系统的更多信息。

    51. 在Linux中,lsof命令是什么?

    回答: lsof表示文件列表,我们可以知道哪个进程打开了哪个文件。

    1个
    2
    #lsof
    -

    52.解释chmod命令吗?

    回答:此命令用于更改文件和目录的权限。这是一个重要的命令,因此,我将对其进行简要说明。因此,总的来说,共有三种权限,即读,写和执行,并由数字表示,如下所示。

    1. 4-读取权限
    2. 2-写入权限
    3. 1-执行权限

    句法:

    1个
    2
    3
    4
    5
    6
    7
    $ chmod options permissions file name 
     
    $ chmod [OPTION]... MODE[,MODE]... FILE...
     
    $ chmod [OPTION]... OCTAL-MODE FILE...
     
    $ chmod [OPTION]... --reference=RFILE FILE…

    53.解释chown命令吗?

    回答: Chown命令:命令“ chown”代表变更文件的所有者和组。此命令用于更改指定用户或组的一个或多个文件或文件夹的所有权。 

    句法:

    1个
    2
    3
    4
    $ chown [OPTION]… [OWNER][:[GROUP]] FILE…
                                    Or
     
      $ chown [OPTION]… –reference=RFILE FILE…

    54.在Linux中什么是cp命令?

    回答: cp命令: cp命令用于复制文件和目录。它还用于备份文件或目录。

    句法:

    $ cp文件名

    55.如何在Linux中从系统中删除文件或目录?

    回答:  rm命令:rm命令用于删除命令行上指定的目录或文件。删除任何文件或目录时,请务必小心。

    句法:

    rm文件名- 

    命令描述
    rm文件名删除单个文件。
    rm filename1,filename2,filename 3删除多个文件。
     rm * .pdf删除当前目录中的所有pdf文件。 
     rm -i 文件名-i表示在删除文件之前先进行确认
     rm -i 文件名删除文件而不提示
    rm -fv * .txt删除当前目录中的所有.txt文件而不提示

    56. Linux中的mkdir是什么?

    回答: mkdir,命令允许用户在Linux中创建目录。用户可以一次创建多个目录,并可以设置目录的权限。

    句法: 

    mkdir [选项...] [目录...]

    选项描述
    Directory要创建的目录的名称
    -m=mode, --mode=mode为创建的目录设置文件模式(权限等)
    -p, --parents创建父目录
    --v,--verbose详细输出。打印已创建目录的消息。
    --Z= context, --context=context如果使用的是SELinux,则此选项将每个创建的目录的安全性上下文设置为context。
    --help显示帮助消息并退出
    --version它显示版本信息并退出

    57.在Linux中解释rmdir命令?

    回答:  rmdir用于删除命令行上指定的每个目录。 

    句法: 

    1个
    rmdir [-p] [-v | –verbose] [–ignore-fail-on-non-empty] directories

    58.如何退出vi编辑器?

    回答:我们可以使用两个命令退出vi编辑器。他们是

    • Wq  wq命令保存当前工作并从vi编辑器退出。
    • q!: q!命令不会保存当前的工作,但是会从vi编辑器中退出。

    59.如何从vi中的文件中删除信息?

    回答: 以下命令用于在vi编辑器中从文件中删除信息。

    1. 命令x删除当前字符。
    2. 命令dd删除当前行。

    60.征募一些Linux文件内容命令?

    回答:文件内容命令

    1. head:显示文件的顶行。
    2. tail:显示文件的最后几行。
    3. cat:串联两个以上的文件。
    4. 更多:以寻呼机形式显示内容以在终端中查看。 

    Linux技术面试常见问题解答

    61.招募一些Linux发行商(Distros)及其用法?

    回答:我们有很多Linux发行商,其中,我们讨论了一些重要的发行商。

    • Linux Mint:稳定且强大。Linux Mint使用伴侣桌面和肉桂。 
    • Debian:它代表了健壮性,稳定性和上油良好的发布周期。这是用户友好的。Debian版本8将被版本9取代。
    • Ubuntu:它基于Debian,适用于台式机和服务器版本。  
    • openSUSE:对于新用户和现有用户来说,这是一个不错的选择。
    • Manjaro:它为新手和有经验的用户提供了愉快的体验。

    62.为什么我们使用LINUX? 

    回答: 我们有很多原因,其中列出了几个重要的原因。以下是

    • 高稳定性:非常稳定,不会导致崩溃,它可以像首次安装时一样快速运行。 
    • 安全性:这是一台可靠的服务器,可以为用户提供高安全性。在系统上使用Linux很容易避免病毒和恶意软件。攻击者无法更改系统中的任何更改,除非该用户以root用户身份登录。
    • 易于操作: Linux易于操作,并且我们可以轻松地安装到系统上,因为Linux的所有变体都有自己的软件存储库。您可以单击几次以定期更新系统,也可以设置自动更新。
    • 硬件兼容性: Linux可以在任何硬件上使用,它没有任何硬件限制。它有效地使用了所有系统资源。
    • 开源:源代码可用,因为它位于免费和开源软件(FOSS)下。ç¨äºlinuxæä½ç³»ç»

     

     

    63. Linux操作系统有哪些功能?

    回答:以下是Linux操作系统的功能

    • 可移植性:软件可以相同的方式在不同类型的硬件上运行。它可以随身携带笔式驱动器和存储卡。
    • 开源:免费提供源代码及其基于社区的开发项目。 
    • 多用户:多个用户可以同时使用ram,应用程序和运行程序。 
    • 多重编程多个程序或应用程序可以同时运行。 
    • Shell:它具有特殊的解释程序,您可以在其中执行系统的程序和命令。 
    • 安全性:它提供身份验证,授权和加密,以提供数据的安全性。 

    64.区分BASH和DOS?

    答: 

    重击多斯
    命令区分大小写命令不区分大小写
    反斜杠(/)表示目录分隔符'/'代表命令参数
    正斜杠“”表示转义字符''代表目录分隔符
    不遵循文件中的约定命名  遵循文件中的命名约定

    65.内部命令和外部命令是什么意思?

    答: 

    • 内部命令:直接由外壳运行的命令称为内部命令,没有单独的进程来运行命令。 
    • 外部命令: 内核运行的命令称为外部命令,每个命令都有其自己唯一的进程ID。

    Linux网络面试问题

    66. Linux中的PIPE是什么意思?

     
     

    回答:这是一种重定向形式,在Linux中使用,用于组合两个以上的命令,一个命令的输出可以作为下一个命令的输入。 

    句法:

    1个
    command_1 | command_2 | command_3 | .... | command_N

    67.描述父子进程如何相互通信?

    回答: 父进程通过使用管道,套接字,消息队列等与子进程进行通信。 

    68.什么是无状态Linux服务器?

    回答:这是一台集中式服务器,在工作站上没有任何存在状态。当特定系统的状态拍摄快照时,用户可能希望所有其他计算机都处于该特定状态,因此可能会出现这种情况。

    69.解释无状态Linux服务器的功能吗?

    答: 

    1. 存储每个系统的原型。
    2. 存储拍摄的快照。 
    3. 存储主目录。
    4. 使用LDAP,其中包含有关哪个快照应在哪个系统上运行的信息。 

    70.什么是僵尸进程?

    回答: 这是一个执行已完成但进程表中甚至存在信息的进程。由于子进程需要读取子进程的状态,因此发生在子进程中。一旦使用wait系统调用完成了该任务,则僵尸进程将从进程表中删除。这被称为僵尸进程。

    71.解释Ctrl + Alt + Del组合键在Linux操作系统上的工作吗?

    回答: 在Linux中,Ctrl + Alt + Del键用于重新启动计算机,并且在重新引导系统之前它不会显示任何确认消息。 

    72.为什么Linux被认为比其他操作系统更安全?

    回答:   Linux是一种开源操作系统,如今它在技术市场中正在迅速增长。我们有几个理由说明Linux比其他操作系统更安全的原因。

    • 帐户特权: Linux仅允许少数用户访问系统。因此,该病毒无法攻击整个系统,它可能仅导致系统中的几个文件。 
    • 强大的社区: Linux用户在打开文件之前首先完成了文件。这样他们就可以避免系统遭受漏洞攻击。 
    • iptables: Linux使用的iptables,因为它检查系统的安全圈。 
    • 不同的工作环境: Linux系统具有不同的工作环境,例如Linux Mint,Debian,Arch等,这些工作环境可以防御病毒。
    • 在Linux中记录:它维护日志历史记录,因为以后可以轻松查看系统文件的详细信息。 
    • 很少的用户: Linux用户比其他用户少,因为这种安全性会更多。

    73.在Linux中,tail命令是什么?

    回答: tail命令显示文件的最后部分。通常,用户不需要每个日志行即可进行故障排除。相反,您想查看日志中有关应用程序最近请求的内容。

    尾例:

    $ tail -n 100 / var / log / httpd / access_log

    74.在Linux中什么是cat命令?

    回答:  在Linux中,cat命令连接并打印文件。用户可能发出cat检查您的依赖项文件的内容或确认您已经在本地构建的应用程序的版本。

    猫示例:

    1个
    2
    3
    $ cat requirements.txt
    flask
    flask_pymongo
     
    重要的Linux命令

     

    75. Linux中的grep命令是什么?

    回答:  grep搜索文件模式。如果要在另一个命令的输出中查找特定模式,则grep突出显示相关行。使用此grep命令搜索日志文件,特定进程等。

    grep示例: 

    1个
    2
    $ cat tomcat.log | grep org.apache.catalina.startup.Catalina.start
    12-Jan-2018 17:08:35.542 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in 681 ms

    76. Linux中的ps命令是什么?

    回答:  ps命令显示进程状态。使用此ps命令来确定正在运行的应用程序或确认预期的进程。

    ps命令示例:

    1个
    2
    3
    $ ps -ef
     
    $ ps -ef | grep tomcat

    77.在Linux中什么是env命令?

    Ans:  env命令允许用户设置或打印环境变量。在故障排除期间,用户会发现它对于检查错误的环境变量是否阻止您的应用程序启动很有用。

    env命令示例:

    1个
    2
    3
    4
    5
    6
    7
    8
    9
    $ env
    PYTHON_PIP_VERSION=9.0.1
    HOME=/root
    DB_NAME=test
    PATH=/usr/local/bin:/usr/local/sbin
    LANG=C.UTF-8
    PYTHON_VERSION=3.4.6
    PWD=/
    DB_URI=mongodb://database:27017/test

    78.什么是Linux中的top命令?

    回答:  top命令显示和更新排序的过程信息。使用此top命令来确定正在运行的进程以及它们消耗了多少内存和CPU。

    79. Linux中的netstat命令是什么?

    回答:  Linux中的netstat命令显示网络状态。此netstat命令显示正在使用的网络端口及其传入连接。

    80.在Linux中,lsof命令是什么?

    回答:命令ls列出了与您的应用程序关联的打开文件。

    81.在Linux中df命令是什么?

    回答:  用户可以使用df命令对磁盘空间问题进行故障排除。此处df表示显示可用磁盘空间。

    df命令示例:

    df -h

    82.在Linux中du命令是什么?

    Linux中的Ans: du命令用于检索有关哪些文件使用目录中磁盘空间的更多详细信息。

    du命令示例:

    1个
    2
    3
    4
    5
    6
    7
    8
    $ du -sh /var/log/*
    1.8M  /var/log/anaconda
    384K  /var/log/audit
    4.0K  /var/log/boot.log
    0 /var/log/chrony
    4.0K  /var/log/cron
    4.0K  /var/log/maillog
    64K /var/log/messages

    83.在Linux中什么是iptables命令?

    回答:  iptables命令阻止或允许Linux主机上的流量,类似于网络防火墙。此iptables命令可能会阻止某些应用程序接收或传输请求。

    Linux与Windows

    LINUX视窗
    Linux是  免费提供的必须购买Windows
    这是  一个开源操作系统它不是开源操作系统
    一个可以定制Linux没有自定义项
    提供高级安全性无法防御病毒和恶意软件攻击
    主分区和逻辑分区可启动仅在主分区时可以启动
    BackSlash分隔目录正斜杠分隔目录
    文件名区分大小写命名文件时不分大小写
     

    84. cd-命令做什么?

    回答:  cd-命令转到上一个目录。

    85. cd命令有什么作用?

    回答:  转到$ HOME目录

    86.(cd dir &&命令)做什么?

    回答:  cd dir &&命令转到dir,执行命令并返回当前目录。

    88. pushed命令有什么作用?

    回答:推送命令将当前目录放到堆栈上,以便您可以弹出它。

    Linux管理员面试问题

    89.什么是ls -lSr命令?

    回答:  ls-ISr命令按大小显示文件,最后显示最大文件。

    90.什么是du -s * | 排序-k1,1rn | 头命令用于?

    回答:  该命令显示当前目录中的顶级磁盘用户。

    91. du -hs / home / * |是什么?sort -k1,1h命令吗?

    回答:  此命令排序路径通过易于解释磁盘使用情况来实现。

    92.什么是df -h命令?

    回答:此命令显示已挂载文件系统上的可用空间。

    93.什么是df -i命令?

    回答: df -I命令显示已挂载文件系统上的空闲索引节点。

    94. fdisk -l命令的作用是什么?

    回答:  fdisk -I命令显示磁盘分区的大小和类型(以root身份运行)。

     查看Linux示例简历

    95.如何在Linux中使用一个端口杀死程序?

    回答: 使用此命令可以通过一个端口杀死程序:sudo fuser -k 8000 / tcp

    96.如何限制命令的内存使用量?

    回答:  ulimit -Sv 1000#1000 KBs = 1 MB
        ulimit -Sv unlimited#删除限制

    97.如何在Linux中获得文件的完整路径?

    <strong style =“ font-family:-apple-system,BlinkMacSystemFont,“ Segoe UI”,Roboto,Oxygen,Ubuntu,Cantarell,“ Open Sans”,“ Helvetica Neue”,sans-serif;颜色:#e74c3c;”>回答:</ strong>:使用以下命令:readlink -f file.txt

    98.如何列出tar.gz的内容并仅提取一个文件?

    回答:  使用以下命令:

    • tar tf file.tgz
    • tar xf file.tgz文件名

    99.您如何找到谁登录?

    回答:  使用此命令可查找登录人员:w

    100.如何检查每个目录对文件的权限?

    回答:  检测权限错误很有用,例如在配置Web服务器时。

    1个
    namei -l /path/to/file.txt

    101.每次修改文件时如何运行命令?

    回答:  使用此命令可以执行以下操作:

    1个
    2
    3
    4
    5
    6
    7
    while inotifywait -e close_write document.tex
     
    do
     
    make
     
    done

    102.如何将文本复制到剪贴板?

    回答:使用此命令:cat file.txt | xclip-选择剪贴板

    103.您如何检查资源使用情况?

    回答:使用此命令检查资源使用情况:/ usr / bin / time -v ls

    104.如何在有限的时间内运行命令?

    回答:使用此命令:超时10秒./script.sh

    #设置为
    true时每30分钟重新启动一次;超时30m ./script.sh; 完成

    105.如何在Linux中将两个已排序文件中的两行合并?

    回答:使用此命令:comm file1 file2。

    展开全文
  • JavaWeb笔记

    千次阅读 多人点赞 2019-09-06 10:42:23
    六、因特网与万维网的关系: 1、“互联网”定义是:“指由若干电子机网络相互连接而成的网络” 2、“因特网”定义是:“目前全球最大的一个电子计算机互联网,是由美国的ARPA网发展演变而来的”。 3、万维网是无数...

    javaweb

    一、JavaWeb的发展历程:静态技术、动态技术及Web2.0新时期

    二、什么是Web:
    World Wide Web 的简称,中文称为万维网
    作用:用于发布、浏览、查询信息的网络信息服务系统、由遍布在不同区域内的web服务器有机组成

    三、HTTP协议:
    超文本传输协议,用于web服务器传输超文本到本地浏览器的传送协议。是一种无状态协议,

    四、URL和Uri的区别:
    URL只是构成Uri的元素。
    1、url:统一资源标志符确定一个资源,
    2、统一资源定位符不但确定一个资源,而且还表示出它在哪里

    五、b/s与c/s
    C/S结构,即Client/Server(客户机/服务器)结构,是大家熟知的软件系统体系结构,通过将任务合理分配到Client端和Server端,降低了系统的通讯开销,可以充分利用两端硬件环境的优势。开发C/S架构可以采用多种语言,包括Java,C++,C#,以及Dephi等

    B/S结构,即Browser/Server(浏览器/服务器)结构,是随着Internet技术的兴起,对C/S结构的一种变化或者改进的结构。在这种结构下,用户界面完全通过WWW浏览器实现。前端 在大部分企业就是做浏览器端展现相关的工作,会用到html,css,js,ps,ai等等,而“后端”的主要工作室程序开发、数据处理了,比如:php,asp,mysql,mssql。

    六、因特网与万维网的关系:
    1、“互联网”定义是:“指由若干电子机网络相互连接而成的网络”
    2、“因特网”定义是:“目前全球最大的一个电子计算机互联网,是由美国的ARPA网发展演变而来的”。
    3、万维网是无数个网络站点和网页的集合,它们在一起构成了因特网最主要的部分(因特网也包括电子邮件、Usenet以及新闻组)。

    七、tomcat服务器的各个目录的功能
    bin:启动、关闭脚本
    lib:日志
    conf:配置文件
    webapps:已发布的web程序

    八、常见的服务器:
    (1)ApacheApache是世界使用排名第一的Web服务器软件。它可以运行在几乎所有广泛使用的计算机平台上。Apache源于NCSAhttpd服务器,经过多次修改,成为世界上最流行的Web服务器软件之一。Apache取自"a patchy server"的读音,意思是充满补丁的服务器,因为它是自由软件,所以不断有人来为它开发新的功能、新的特性、修改原来的缺陷。Apache的特点是简单、速度快、性能稳定,并可做代理服务器来使用。
    (2)IIS是英文Internet Information Server的缩写,译成中文就是"Internet信息服务"的意思。它是微软公司主推的服务器,最新的版本是Windows2008里面包含的IIS 7,IIS与Window Server完全集成在一起,因而用户能够利用Windows Server和NTFS(NT File System,NT的文件系统)内置的安全特性,建立强大,灵活而安全的Internet和Intranet站点。
    (3)GFEGoogle的web服务器,用户数量激增。目前紧逼iis。
    (4)Nginx不仅是一个小巧且高效的HTTP服务器,也可以做一个高效的负载均衡反向代理,通过它接受用户的请求并分发到多个Mongrel进程可以极大提高Rails应用的并发能力。
    (5)Lighttpd是由德国人 Jan Kneschke 领导开发的,基于BSD许可的开源WEB服务器软件,其根本的目的是提供一个专门针对高性能网站,安全、快速、兼容性好并且灵活的web server环境。具有非常低的内存开销,CPU占用率低,效能好,以及丰富的模块等特点。Lighttpd 是众多OpenSource轻量级的web server中较为优秀的一个。支持FastCGI, CGI, Auth, 输出压缩(output compress), URL重写, Alias等重要功能。
    (6)Zeus是一个运行于Unix下的非常优秀的Web Server,据说性能超过Apache,是效率最高的Web Server之一。
    (7)Sun的Java系统Web服务器也就是以前的Sun ONE Web Server。主要出现在那些运行Sun的Solaris操作系统的关键任务级Web服务器上。它最新的版本号是6.1,可以支持x86版本Solaris,Red Hat Linux,HP-UX 11i, IBM AIX,甚至可以支持Windows,但它的大多数用户都选择了SPARC版本的Solaris操作系统。
    (8)Resin提供了最快的jsp/servlets运行平台。在java和javascript的支持下,Resin可以为任务灵活选用合适的开发语言。Resin的一种先进的语言XSL(XML stylesheet language)可以使得形式和内容相分离。
    (9)Jetty是一个开源的servlet容器,它为基于Java的web内容,例如JSP和servlet提供运行环境。Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布。开发人员可以将Jetty容器实例化成一个对象,可以迅速为一些独立运行(stand-alone)的Java应用提供网络和web连接。
    (10)BEA WebLogic是用于开发、集成、部署和管理大型分布式Web应用、网络应用和数据库应用的Java应用服务器。将Java的动态功能和Java Enterprise标准的安全性引入大型网络应用的开发、集成、部署和管理之中。 BEA WebLogic Server拥有处理关键Web应用系统问题所需的性能、可扩展性和高可用性。
    (11)Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持,最新的Servlet 和JSP 规范总是能在Tomcat 中得到体现。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

    第三章:Servlet

    一、什么是Servlet?
    用于接受客户端信息和响应客户端信息
    是网页之间的桥梁
    是用于Java编写的服务器段程序
    Servlet是Java类,继承了HttpServlet,重写dopost和doGet方法,负责服务器端响应与请求
    doget方法需要重编码request.setCharacterEncoding(“utf-8”);
    String 变量名 = new String(变量名.getBytes(“ISO-8859-1”),“UTF-8”);
    response.setContentType(“text/html;charset=utf-8”);
    dopost编码:request.setCharacterEncoding(“utf-8”);

    二、servlet的创建?
    1、创建Java类继承httpservlet
    2、重写doget与dopost方法
    3、配置web.xml的文件。servlet servlet-mapping

    <servlet>
    	<servlet-name>程序名</servlet-name>
    	<servlet-class>包名.类名</servlet-class>
    </servlet>
    <servlet-mapping>
    	<servlet-name>程序名与上相同</servlet-name>
    	<url-pattern>/访问路径(路径前必须加"/")</url-pattern>
    </servlet-mapping>
    

    4、访问Servlet
    超链接 get
    地址栏 get
    表单 get/post

    三、servlet的生命周期

    初始化【1次】–>服务[N次]–>销毁[1次]

    四、编码方式
    javaweb有哪些编码:gb2312 GBK UTF-8
    中文乱码处理:get提交中需要通过再编码方式来完成

    五、会话过程

    1、什么是会话?
    
    	客户端的1次请求与服务器端的一次响应
    
    2、什么是会话跟踪?
    
    	在多次会话过程中能够记录客户端信息
    
    3、为什么要使用会话跟踪?
    
    	http协议是属于一种无状态的协议,不会记录客户端的信息。
    
    4、有哪些会话跟踪
    
    	session,cookie
    
    	session:将数据保存到服务器中,客户端30分钟无操作或者关闭客户端将会销毁
    
    	cookie:将数据保存到本地,因为对网络用户隐私构成危害,目前正被禁止使用
    
    5、会话跟踪的技术
    
      	 HttpSession	session  =request.getSession();
    
    6、会话生命周期?
    
    	发求请求到服务器响应结束,一般按照关闭浏览器,如果客户端在30分钟内没有发起任何数据交互则会话自动结束
    

    六、跳转

    内部跳转:转发  request
    
    		1、内部跳转可以携带数据
    
    		2、地址栏不会发生变化
    
    
    外部跳转:重定向  response
    
    		1、不可以携带数据
    
    		2、地址栏会发生变化
    

    七、作用:

    1、根据客户端的请求动态生成完整的HTML网页,并返回给客户端
    
    2、接受和响应客户端的信息
    

    JSP

    一、什么是JSP?

    JSP是由java+javascript+page组合,JSP是一种能够支持Java代码的一种动态网页   
    

    二、为什么要使用JSP?

    JSP支持Java代码以及可以在JSP中实现页面展示
    

    三、JSP的运行原理?

    JSP最终会被编译成为Servlet
    
    JSP:编写--》翻译-》编译-->执行
    
    	JSP最终会变成一个class文件
    
    为什么JSP第一次打开会比较慢?
    
    	因为第一次的打开JSP要经过翻译,编译,执行过程需要消耗时间,而第二次打开不需要再经过翻译和编译,可以直接执行,后面没有改动的情况下打开速度很快
    

    四、JSP组成?

    1、HTML
    
    2、指令  <%@   %>
    
    		导入包,编码,error页面
    	
    		<%@ include  file="文件路径" %>  JSP中包含一个文件
    
    3、小脚本
    		<% 小脚本java代码 %>
    
    4、声明
    		
    		<%!   %>
    
    5、输出
    
    	<%= 输出内容  %> 不能以分号结尾
    
    6、注释
    
    	<%-- -- %>  JSP注释是给程序员看的注释  隐式注释
    
    	<!--  -->  HTML注释,是可以给所有看   显示注释
    
    7、动作
    
    	<jsp:include page="myfile.txt"></jsp:include>
    
    	<jsp:forward page="index1.jsp"></jsp:forward>跳转页面
    

    内置对象

    一、什么是内置对象?

    不需要使用new关键字创建则可以直接使用,在系统中自动编译
    

    二、JSP中有哪些内置对象?

    9个
    
    out、request、response、session、application、page、pagecontext、config、Exception
    

    三、每一个内置对象的作用以及方法?

    out:输出
    
    	out.write()
    
    	out.print()
    
    request:接收请求
    
    	request.setAttribute("name",value);设置存入的数据
    
    		getAttribute(name);
    
    		removeAttribute("name");
    
    		getParameter();得到请求的参数
    
    		getParameterValues();接收的多个请求的name一致
    	跳转:
    
    		request.getRequestDispatcher("index.jsp").forward(request, response);
    
    
    response:响应请求
    
    	response.sendRedirect(arg0);外部跳转
    
    	response.setHeader("refresh","刷新时间间隔;目的页面地址");
    
    session:会话
    
    	session.setAttribute("name",value);设置存入的数据
    
    		getAttribute(name);
    
    		removeAttribute("name");
    
    application:服务器开启到服务器关闭
    
    		setAttribute("name",value);设置存入的数据
    
    		getAttribute(name);
    
    		removeAttribute("name");
    
    pagecontext:对当前操作
    
    		setAttribute("name",value);设置存入的数据
    
    		getAttribute(name);
    
    		removeAttribute("name");
    
    config:获取web.xml的配置信息
    
    		config.getInitParameter("myservlet");
    
    exception:获取异常页面信息
    
    		注意:isErrorPage="true"必须为true否则exception无法使用
    
    			errorpage="错误.jsp";跳转到错误页面
    

    四、内置对象的作用域?作用域对象

    	page  request    session    application
    
    	page:当前页有效
    
    	request:内部跳转有效
    
    	session:整个会话有效
    
    	application:服务器开启到服务器关闭有效
    
    
    作用域的范围顺序:page <  request <  session   <  application
    
    
    问?
    
    	如果4个作用都能完成某一个操作,你会选择谁?
    
    		能使用小范围则不选择大范围作用。因为范围约到占用的资源越多,消耗性能越高.
    

    常用方法:

    //获取客户端访问的真实IP	
    request.getRemoteAddr();
    
    //刷新页面
    response.setHeader("refresh","刷新时间间隔;目的页面地址");
    

    JavaBean与动作

    一、什么是JavaBean?
    
    Javabean是一个Java类,拥有特殊的用途,和自己的封装方式 通过get和set对业务数据进行封装
    
    
    二、JavaBean的作用?
    
    1、封装业务逻辑
    
    2、减少代码,代码的重复使用
    
    三、JavaBean所拥有的特征?
    
    1、是Java类
    
    2、get和set方法
    
    3、必须有一个无参的构造方法
    
    4、公共的
    
    四、如何创建JavaBean?
    
    1、创建Java
    
    2、获取业务数据
    
    3、得到封装数据的方法
    
    4、得到一个无参的构造方法
    
    五、jsp+javabean的具体实现?
    
    登陆
    
    动作+JavaBean:减少JSP中出现的大量的Java代码
    
    
    六、动作的具体说明
    
    	<jsp:useBean id="创建对象名"  class="com.zuxia.JavaBean【JavaBean路径  包+类】" scope="作用域page/request/session/application" ></jsp:useBean>
    
    		替换的代码是:
    					//接收提交过来的用户名和密码
    				//	String name = request.getParameter("name");
    					
    				//	String pwd = request.getParameter("pwd");					
    					//创建一个实体类
    					//JavaBean  jab=new JavaBean();
    
    	<jsp:setProperty property="表单提交的name" name="对象名"/>	
    
    		替换的代码是:request.setAttribute(name, value);
    
    	<jsp:getProperty property="表单提交的name" name="对象名"/>	
    		替换的代码是:request.getAttribute(name)
    
    
    格式:
    
    创建对象、相当于——类名 对象名 = new 类名()
    	<jsp:useBean id="jab"  class="com.zuxia.JavaBean" scope="session" ></jsp:useBean>
    	<jsp:useBean id="创建的对象名" class="包名.类名" scop="作用域(page、request、session、application)"></jsp:useBean>
    
    设置对象中的属性值:相当于——request.setAttribute(name,value)
    
    	<jsp:setProperty property="name" name="jab"/>
    	<jsp:setProperty property="标签中name属性的值" name="对象名"/>
    
    得到对象中属性值:相当于request.getAttribute(name)
    

    第八章:MVC模式

    Model1:主要使用JSP和JavaBean开发web应用,JavaBean封装对数据库的操作盒部分业务逻辑的代码,JSP即会包含输出效果的HTML、CSS代码,也会包含业务逻辑的Java代码
    
    Model2:MVC即模型(Model)-视图(View)-控制器(Controller)它降低了代码的耦合度,提高了代码的重用性,是一种把JSP与servlet联合使用来实现动态内容服务的方法,项目越复杂,使用Model2体系结构的好处越大
    
    优点:
    
    	1、各司其职,互不干涉
    
    	2、有利于开发中的分工
    
    	3、有利于组件的重用
    
    缺点:
    	对开发人员技术水平要求高,模型和视图的分离也使得调试代码更困难,但是MVC仍然是web程序最好的架构模式	
    

    Ajax的应用

    js:
    	//获取XMLHttpRequest对象
    	var xml = new XMLHttpRequest();
    	//设置发送请求参数一:提交方式:post、get。参数二:提交路径,参数三:是否异步
    	xml.open("post","Servlet?name="+name,true);
    	//发送
    	xml.send();
    
    	//获取服务器状态
    	xml.onreadystatechange = function(){
    
    		if(xml.status==200&&xml.readyState==4){
    			//responseText是服务器端响应的数据
    			if(xml.responseText=="true"){
    				alert('用户名存在');
    			//	window.location.href="index.jsp";
    			}else{
    				alert('用户名不存在');
    			//	window.location.href="index.jsp";
    			}
    
    		}
    
    	}
    
    展开全文
  • 近期总结一一些面试题 都是企业的面试题笔记题 感觉薪资10k下的都会出笔试题 特别高的薪资都是直接技术面试或者是 现场编程 总结很多人的面试题,后期会对于单个知识点再说笔记详细讲解。 ...

    近期总结一一些面试题 都是企业的面试题笔记题

    感觉薪资10k下的都会出笔试题   

    特别高的薪资都是直接技术面试或者是 现场编程 

    总结很多人的面试题,后期会对于单个知识点再说笔记详细讲解。

    最新Vue面试题网址:2021年 Vue经典面试题 -- 必问知识点 --(包含答案)_xm1037782843的博客-CSDN博客_vue面试题

    敬请关注公众 :包含全套 Vue 最新面试题  js最近面试题 等大量前端知识技术。

     

    部分都是百度的答案,不是特全面的,可以自己找下

    同时分享一个自己录制的CSS3动画特效经典案例【推荐教程】--后期会更新vue框架 微信小程序等内容。

    最近录制的ajax从基础到实战的视频,包含原生ajax  jquery的ajax 以及ajax接口获取数据等

    Ajax前端开发、项目实战、从零基础到精通、接口数据调用-学习视频教程-腾讯课堂

    红色为常见面试题

    =============================================================

    前端面试题: 

    1. 一个200*200的div在不同分辨率屏幕上下左右居中,用css实现

    <div style="width:500px;height:500px;border:1px solid green;display:flex;justify-content:center;align-items:center;">
      <div style="">
        上下左右居中
      </div>
    </div>

    2. 写一个左中右布局占满屏幕,其中左右两块是固定宽度200 ,中间自适应宽,要求先加载中间块,请写出结构及样式:

    <div id="left">我是左边</div>
        <div id="center">我是中间</div>
        <div id="right">我是右边</div>
    
    html,body{ margin: 0px;width: 100%; } 
    #left,#right{width: 200px;height: 200px;background-color: aqua;
        position: absolute;}
        #left{left: 0;top:0;}
        #right{right: 0;top:0;}
        #center{margin: 0 200px;background-color: blue;height: 200px;}

    或者利用弹性盒子

        <style>
            * {
                margin: 0;
                padding: 0;
            }
    
            html,
            body {
                height: 100%;
            }
    
            body {
                display: flex;
            }
    
            .left {
                width: 100px;
                background-color: rgb(199, 170, 223);
            }
    
            .center {
                background-color: rgb(151, 228, 148);
                flex: 1;
            }
    
            .right {
                width: 100px;
                background-color: rgb(199, 170, 223);
    
    
            }
        </style>
    
    <body>
        <div class="left">left</div>
        <div class="center">center</div>
        <div class="right">right</div>
    </body>
    

    3. 阐述清楚浮动的几种方式(常见问题)

    1.父级div定义 height

    原理:父级div手动定义height,就解决了父级div无法自动获取到高度的问题。
    优点:简单、代码少、容易掌握
    缺点:只适合高度固定的布局,要给出精确的高度,如果高度和父级div不一样时,会产生问题

    2.父级div定义 overflow:hidden

    原理:必须定义width或zoom:1,同时不能定义height,使用overflow:hidden时,浏览器会自动检查浮动区域的高度
    优点:简单、代码少、浏览器支持好

    4. 结尾处加空div标签 clear:both

    原理:添加一个空div,利用css提高的clear:both清除浮动,让父级div能自动获取到高度
    优点:简单、代码少、浏览器支持好、不容易出现怪问题

    缺点:不少初学者不理解原理;如果页面浮动布局多,就要增加很多空div,让人感觉很不好

    5. 解释css sprites ,如何使用?

    CSS Sprites其实就是把网页中一些背景图片整合到一张图片文件中,再利用CSS的“background-image”,“background- repeat”,“background-position”的组合进行背景定位,background-position可以用数字能精确的定位出背景图片的位置。

    CSS Sprites为一些大型的网站节约了带宽,让提高了用户的加载速度和用户体验,不需要加载更多的图片

    6. 如何用原生js给一个按钮绑定两个onclick事件?

    Var  btn=document.getElementById(‘btn’);

    //事件监听 绑定多个事件

    var btn4 = document.getElementById("btn4");

    btn4.addEventListener("click",hello1);

    btn4.addEventListener("click",hello2);

    function hello1(){

     alert("hello 1");

    }

    function hello2(){

     alert("hello 2");

    }

    7. 拖拽会用到哪些事件

    · dragstart:拖拽开始时在被拖拽元素上触发此事件,监听器需要设置拖拽所需数据,从操作系统拖拽文件到浏览器时不触发此事件.

    · dragenter:拖拽鼠标进入元素时在该元素上触发,用于给拖放元素设置视觉反馈,如高亮

    · dragover:拖拽时鼠标在目标元素上移动时触发.监听器通过阻止浏览器默认行为设置元素为可拖放元素.

    · dragleave:拖拽时鼠标移出目标元素时在目标元素上触发.此时监听器可以取消掉前面设置的视觉效果.

    · drag:拖拽期间在被拖拽元素上连续触发

    · drop:鼠标在拖放目标上释放时,在拖放目标上触发.此时监听器需要收集数据并且执行所需操作.如果是从操作系统拖放文件到浏览器,需要取消浏览器默认行为.

    · dragend:鼠标在拖放目标上释放时,在拖拽元素上触发.将元素从浏览器拖放到操作系统时不会触发此事件.

    8. 请列举jquery中的选择器:

    9. Javascript中的定时器有哪些?他们的区别及用法是什么?

    setTimeout 只执行一次
    setInterval 会一直重复执行

    9.请描述一下 cookies sessionStorage和localstorage区别

    相同点:都存储在客户端
    不同点:1.存储大小

    · cookie数据大小不能超过4k。

    · sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大。

    2.有效时间

    · localStorage    存储持久数据,浏览器关闭后数据不丢失除非主动删除数据;

    · sessionStorage  数据在当前浏览器窗口关闭后自动删除。

    · cookie          设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭

    3. 数据与服务器之间的交互方式

    · cookie的数据会自动的传递到服务器,服务器端也可以写cookie到客户端

    · sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存。

    10.计算一个数组arr所有元素的和

    var arr1=[1,2,3,4,5,6,7,8,9];

    var sum1=0;

    for (var i=0;i<=arr1.length;i++) {

    if (typeof arr1[i]=="number") {

    sum1+=arr1[i];

    }

    }

    document.write(sum1);

    //====================================

    function sum2(arr){

    var all=0;

    for (var i=0;i<arr.length;i++) {

    if (typeof arr[i]=="number") {

    all+=arr[i];

    }

    }

    return all;

    }

    document.write(sum2([1,2,3,4]));

    11.编写一个方法去掉数组里面 重复的内容  var arr=[1,2,3,4,5,1,2,3]

    一个数组去重的简单实现

     

    var arr = ['abc','abcd','sss','2','d','t','2','ss','f','22','d'];

    //定义一个新的数组

    var s = [];

    //遍历数组

    for(var i = 0;i<arr.length;i++){

        if(s.indexOf(arr[i]) == -1){  //判断在s数组中是否存在,不存在则push到s数组中

            s.push(arr[i]);

        }

    }

    console.log(s);

    //输出结果:["abc", "abcd", "sss", "2", "d", "t", "ss", "f", "22"]

    方法二:用sort()  然后相邻比较也可以实现

    12.document.write和innerHTML的区别:

    document.write是直接写入到页面的内容流,如果在写之前没有调用document.open, 浏览器会自动调用open。每次写完关闭之后重新调用该函数,会导致页面被重写。

    innerHTML则是DOM页面元素的一个属性,代表该元素的html内容。你可以精确到某一个具体的元素来进行更改。如果想修改document的内容,则需要修改document.documentElement.innerElement。

    innerHTML将内容写入某个DOM节点,不会导致页面全部重绘

     

    innerHTML很多情况下都优于document.write,其原因在于其允许更精确的控制要刷新页面的那一个部分。

    13.ajax的步骤

    什么是ajax?

    ajax(异步javascript xml) 能够刷新局部网页数据而不是重新加载整个网页。

    如何使用ajax?

    第一步,创建xmlhttprequest对象,var xmlhttp =new XMLHttpRequest();XMLHttpRequest对象用来和服务器交换数据。

    var xhttp;

    if (window.XMLHttpRequest) {

    //现代主流浏览器

    xhttp = new XMLHttpRequest();

    } else {

    // 针对浏览器,比如IE5或IE6

    xhttp = new ActiveXObject("Microsoft.XMLHTTP");

    }

    第二步,使用xmlhttprequest对象的open()和send()方法发送资源请求给服务器。

    第三步,使用xmlhttprequest对象的responseText或responseXML属性获得服务器的响应。

    第四步,onreadystatechange函数,当发送请求到服务器,我们想要服务器响应执行一些功能就需要使用onreadystatechange函数,每次xmlhttprequest对象的readyState发生改变都会触发onreadystatechange函数

    14.xml和json的区别,请用四个词语来形容

    ·  JSON相对于XML来讲,数据的体积小,传递的速度更快些

    ·  JSON与JavaScript的交互更加方便,更容易解析处理,更好的数据交互

    ·  XML对数据描述性比较好;

    ·  JSON的速度要远远快于XML

     

    15.清楚浮动的方法?(多次出现在面试题)

    1.父级div定义 height
    原理:父级div手动定义height,就解决了父级div无法自动获取到高度的问题。
    优点:简单、代码少、容易掌握

    缺点:只适合高度固定的布局,要给出精确的高度,如果高度和父级div不一样时,会产生问题

    2,结尾处加空div标签 clear:both

    原理:添加一个空div,利用css提高的clear:both清除浮动,让父级div能自动获取到高度
    优点:简单、代码少、浏览器支持好、不容易出现怪问题
    缺点:不少初学者不理解原理;如果页面浮动布局多,就要增加很多空div,让人感觉很不好
    3,父级div定义 伪类:after 和 zoom

    原理:IE8以上和非IE浏览器才支持:after,原理和方法2有点类似,zoom(IE转有属性)可解决ie6,ie7浮动问题
    优点:浏览器支持好、不容易出现怪问题(目前:大型网站都有使用,如:腾迅,网易,新浪等等)
    缺点:代码多、不少初学者不理解原理,要两句代码结合使用才能让主流浏览器都支持
    4,父级div定义 overflow:hidden

    原理:必须定义width或zoom:1,同时不能定义height,使用overflow:hidden时,浏览器会自动检查浮动区域的高度
    优点:简单、代码少、浏览器支持好
    缺点:不能和position配合使用,因为超出的尺寸的会被隐藏。

     

    16.box-sizing常用的属性有哪些?分别有什么作用?

    属性值

    · box-sizing:content-box

    · box-sizing:border-box

    · box-sizing:inherit

     

    content-box

    · 这是box-sizing的默认属性值

    · 是CSS2.1中规定的宽度高度的显示行为

    · 在CSS中定义的宽度和高度就对应到元素的内容框

    · 在CSS中定义的宽度和高度之外绘制元素的内边距和边框

     

    border-box

    · 在CSS中微元素设定的宽度和高度就决定了元素的边框盒

    · 即为元素在设置内边距和边框是在已经设定好的宽度和高度之内进行绘制

    · CSS中设定的宽度和高度减去边框和内间距才能得到元素内容所占的实际宽度和高度

    (Q1)box-sizing: content-box|border-box|inherit;
    (Q2)content-box:宽度和高度分别应用到元素的内容框。在宽度和高度之外绘制元素的内边距和边框(元素默认效果)。
    border-box:元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制。通过从已设定的宽度和高度分别减去边框和内边距才能得到内容的宽度和高度。

     

    17.css选择器有哪些,选择器的权重的优先级

    选择器类型

    1、ID  #id

    2、class  .class

    3、标签  p

    4、通用  *

    5、属性  [type="text"]

    6、伪类  :hover

    7、伪元素  ::first-line

    8、子选择器、相邻选择器

    三、权重计算规则

    1. 第一等:代表内联样式,如: style=””,权值为1000。

    2. 第二等:代表ID选择器,如:#content,权值为0100。

    3. 第三等:代表类,伪类和属性选择器,如.content,权值为0010。

    4. 第四等:代表类型选择器和伪元素选择器,如div p,权值为0001。

    5. 通配符、子选择器、相邻选择器等的。如*、>、+,权值为0000。

    6. 继承的样式没有权值。

    18. 块级元素水平垂直居中的方法有哪些(三个方法)

    让div等块级元素水平和垂直都居中,即永远处于屏幕的正中央,当我们做如登录块时非常有用!

     实现一、原理:要让div等块级元素水平和垂直居中,必需知道该div等块级元素的宽度和高度,然后设置位置为绝对位置,距离页面窗口左边框和上边框的距离设置为50%,这个50%就是指页面窗口的宽度和高度的50%,最后将该div等块级元素分别左移和上移,左移和上移的大小就是该div等块级元素宽度和高度的一半。

       CSS代码:

    .mycss{ 

       width:300px;  

       height:200px;  

       position:absolute;  

       left:50%;  

       top:50%;  

       margin:-100px 0 0 -150px }

     实现二原理:利用CSS的margin设置为auto让浏览器自己帮我们水平和垂直居中。

       CSS代码:

    .mycss{

        position: absolute;

        left: 0px;

        right: 0;

        top: 0;

        bottom: 0;

        margin: auto;

        height: 200px;

        width: 300px;

    }

    jQuery实现水平和垂直居中

     原理:jQuery实现水平和垂直居中的原理就是通过jQuery设置div等块级元素的CSS,获取div等块级元素的左、上的边距偏移量,边距偏移量的算法就是用页面窗口 的宽度减去该div等块级元素的宽度,得到的值再除以2即左偏移量,右偏移量算法相同。注意div等块级元素的CSS设置要在resize()方法中完成,就是每次改变窗口大 小时,都要执行设置div等块级元素的CSS。

    jquery代码:

    $(window).resize(function(){

        $(".myblock").css({

            position: "absolute",

            left: ($(window).width() - $(".myblock").outerWidth())/2,

            top: ($(window).height() - $(".myblock").outerHeight())/2     });        

    });

    此外在页面载入时,就需要调用resize()方法

    $(function(){

        $(window).resize();

    });

     

    19.三个盒子,左右定宽,中间自适应有几种方法

    第一种:左右侧采用浮动 中间采用margin-left 和 margin-right 方法。

    代码如下:

    <div style="width:100%; margin:0 auto;"> 

     

           <div style="width:200px; float:right; background-color:#960">这是右侧的内容 固定宽度</div>

     

           <div style="width:150px; float:left; background:#6FF">这是左侧的内容 固定宽度</div>

     

           <div style="margin-left:150px;margin-right:200px; background-color:#9F3">中间内容,自适应宽度</div>

     

        </div>

    第二种:左右两侧采用绝对定位 中间同样采用margin-left margin-right方法:

     

    第三种负的margin

    使用这种方法就稍微复杂了一些了,使用的是负的margin值,而且html标签也增加了,先来看其代码吧:

    <div id="main">

     <div id="mainContainer">main content</div></div><div id="left">

     <div id="leftContainer" class="inner">left content</div></div><div id="right">

     <div id="rightContainer" class="inner">right</div></div>

    #main {

     float: left;

     width: 100%;

    }

    #mainContainer {

     margin: 0 230px;

     height: 200px;

     background: green;

    }

    #left {

     float: left;

     margin-left: -100%;

     width: 230px} 

    #right {

     float: left;

     margin-left: -230px;

     width: 230px;

    } 

    #left .inner,

    #right .inner {

     background: orange;

     margin: 0 10px;

     height: 200px;

    }

    20.js有几种数据类型,其中基本数据类型有哪些

    五种基本类型: Undefined、Null、Boolean、Number和String。

    1中复杂的数据类型————Object,Object本质上是由一组无序的名值对组成的。

    Object、Array和Function则属于引用类型

     

    21.undefined 和 null 区别

     

    null: Null类型,代表“空值”,代表一个空对象指针,使用typeof运算得到 “object”,所以你可以认为它是一个特殊的对象值。

    undefined: Undefined类型,当一个声明了一个变量未初始化时,得到的就是undefined。

    null是javascript的关键字,可以认为是对象类型,它是一个空对象指针,和其它语言一样都是代表“空值”,不过 undefined 却是javascript才有的。undefined是在ECMAScript第三版引入的,为了区分空指针对象和未初始化的变量,它是一个预定义的全局变量。没有返回值的函数返回为undefined,没有实参的形参也是undefined。

     

    javaScript权威指南: null 和 undefined 都表示“值的空缺”,你可以认为undefined是表示系统级的、出乎意料的或类似错误的值的空缺,而null是表示程序级的、正常的或在意料之中的值的空缺。

    22.http 和 https 有何区别?如何灵活使用?

     

    http是HTTP协议运行在TCP之上。所有传输的内容都是明文,客户端和服务器端都无法验证对方的身份。

    https是HTTP运行在SSL/TLS之上,SSL/TLS运行在TCP之上。所有传输的内容都经过加密,加密采用对称加密,但对称加密的密钥用服务器方的证书进行了非对称加密。此外客户端可以验证服务器端的身份,如果配置了客户端验证,服务器方也可以验证客户端的身份


    23.常见的HTTP状态码

    2开头 (请求成功)表示成功处理了请求的状态代码。

    200   (成功)  服务器已成功处理了请求。 通常,这表示服务器提供了请求的网页。 
    201   (已创建)  请求成功并且服务器创建了新的资源。 
    202   (已接受)  服务器已接受请求,但尚未处理。 
    203   (非授权信息)  服务器已成功处理了请求,但返回的信息可能来自另一来源。 
    204   (无内容)  服务器成功处理了请求,但没有返回任何内容。 
    205   (重置内容) 服务器成功处理了请求,但没有返回任何内容。
    206   (部分内容)  服务器成功处理了部分 GET 请求。

    3开头 (请求被重定向)表示要完成请求,需要进一步操作。 通常,这些状态代码用来重定向。

    300   (多种选择)  针对请求,服务器可执行多种操作。 服务器可根据请求者 (user agent) 选择一项操作,或提供操作列表供请求者选择。 
    301   (永久移动)  请求的网页已永久移动到新位置。 服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置。
    302   (临时移动)  服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。
    303   (查看其他位置) 请求者应当对不同的位置使用单独的 GET 请求来检索响应时,服务器返回此代码。
    304   (未修改) 自从上次请求后,请求的网页未修改过。 服务器返回此响应时,不会返回网页内容。 
    305   (使用代理) 请求者只能使用代理访问请求的网页。 如果服务器返回此响应,还表示请求者应使用代理。 
    307   (临时重定向)  服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。

    4开头 (请求错误)这些状态代码表示请求可能出错,妨碍了服务器的处理。

    400   (错误请求) 服务器不理解请求的语法。 
    401   (未授权) 请求要求身份验证。 对于需要登录的网页,服务器可能返回此响应。 
    403   (禁止) 服务器拒绝请求。
    404   (未找到) 服务器找不到请求的网页。
    405   (方法禁用) 禁用请求中指定的方法。 
    406   (不接受) 无法使用请求的内容特性响应请求的网页。 
    407   (需要代理授权) 此状态代码与 401(未授权)类似,但指定请求者应当授权使用代理。
    408   (请求超时)  服务器等候请求时发生超时。 
    409   (冲突)  服务器在完成请求时发生冲突。 服务器必须在响应中包含有关冲突的信息。 
    410   (已删除)  如果请求的资源已永久删除,服务器就会返回此响应。 
    411   (需要有效长度) 服务器不接受不含有效内容长度标头字段的请求。 
    412   (未满足前提条件) 服务器未满足请求者在请求中设置的其中一个前提条件。 
    413   (请求实体过大) 服务器无法处理请求,因为请求实体过大,超出服务器的处理能力。 
    414   (请求的 URI 过长) 请求的 URI(通常为网址)过长,服务器无法处理。 
    415   (不支持的媒体类型) 请求的格式不受请求页面的支持。 
    416   (请求范围不符合要求) 如果页面无法提供请求的范围,则服务器会返回此状态代码。 
    417   (未满足期望值) 服务器未满足"期望"请求标头字段的要求。

    5开头(服务器错误)这些状态代码表示服务器在尝试处理请求时发生内部错误。 这些错误可能是服务器本身的错误,而不是请求出错。

    500   (服务器内部错误)  服务器遇到错误,无法完成请求。 
    501   (尚未实施) 服务器不具备完成请求的功能。 例如,服务器无法识别请求方法时可能会返回此代码。 
    502   (错误网关) 服务器作为网关或代理,从上游服务器收到无效响应。 
    503   (服务不可用) 服务器目前无法使用(由于超载或停机维护)。 通常,这只是暂时状态。 
    504   (网关超时)  服务器作为网关或代理,但是没有及时从上游服务器收到请求。 
    505   (HTTP 版本不受支持) 服务器不支持请求中所用的 HTTP 协议版本。

     

     

    24. 如何进行网站性能优化

    1. 从用户角度而言,优化能够让页面加载得更快、对用户的操作响应得更及时,能够给用户提供更为友好的体验。
    2. 从服务商角度而言,优化能够减少页面请求数、或者减小请求所占带宽,能够节省可观的资源。
      总之,恰当的优化不仅能够改善站点的用户体验并且能够节省相当的资源利用。
      前端优化的途径有很多,按粒度大致可以分为两类,第一类是页面级别的优化,例如 HTTP请求数、脚本的无阻塞加载、内联脚本的位置优化等 ;第二类则是代码级别的优化,例如 Javascript中的DOM 操作优化、CSS选择符优化、图片优化以及 HTML结构优化等等。另外,本着提高投入产出比的目的,后文提到的各种优化策略大致按照投入产出比从大到小的顺序排列。
      一、页面级优化
    1. JavaScript 压缩和模块打包
    2. 按需加载资源
    3. 在使用 DOM 操作库时用上 array-ids
    4. 缓存
    5. 启用 HTTP/2
    6. 应用性能分析
    7. 使用负载均衡方案
    8. 为了更快的启动时间考虑一下同构
    9. 使用索引加速数据库查询
    10. 使用更快的转译方案
    11. 避免或最小化 JavaScript 和 CSS 的使用而阻塞渲染
    12. 用于未来的一个建议:使用 service workers + 流
    13. 图片编码优化

    25. react和vue有哪些不同,说说你对这两个框架的看法

    相同点

    · 都支持服务器端渲染

    · 都有Virtual DOM,组件化开发,通过props参数进行父子组件数据的传递,都实现webComponent规范

    · 数据驱动视图

    · 都有支持native的方案,React的React native,Vue的weex

    不同点

    · React严格上只针对MVC的view层,Vue则是MVVM模式

    · virtual DOM不一样,vue会跟踪每一个组件的依赖关系,不需要重新渲染整个组件树.而对于React而言,每当应用的状态被改变时,全部组件都会重新渲染,所以react中会需要shouldComponentUpdate这个生命周期函数方法来进行控制

    · 组件写法不一样, React推荐的做法是 JSX + inline style, 也就是把HTML和CSS全都写进JavaScript了,即'all in js'; Vue推荐的做法是webpack+vue-loader的单文件组件格式,即html,css,jd写在同一个文件;

    · 数据绑定: vue实现了数据的双向绑定,react数据流动是单向的

    · state对象在react应用中不可变的,需要使用setState方法更新状态;在vue中,state对象不是必须的,数据由data属性在vue对象中管理

    26.什么是mvvm mvc是什么区别 原理

    一、MVC(Model-View-Controller)

    MVC是比较直观的架构模式,用户操作->View(负责接收用户的输入操作)->Controller(业务逻辑处理)->Model(数据持久化)->View(将结果反馈给View)。

    MVC使用非常广泛,比如JavaEE中的SSH框架

     

    三、MVVM(Model-View-ViewModel)

    如果说MVP是对MVC的进一步改进,那么MVVM则是思想的完全变革。它是将“数据模型数据双向绑定”的思想作为核心,因此在View和Model之间没有联系,通过ViewModel进行交互,而且Model和ViewModel之间的交互是双向的,因此视图的数据的变化会同时修改数据源,而数据源数据的变化也会立即反应view

    27.px和em的区别

    px表示像素 (计算机屏幕上的一个点:1px = 1/96in),是绝对单位,不会因为其他元素的尺寸变化而变化;

    · 

    · 

    em表示相对于父元素的字体大小。em是相对单位 ,没有一个固定的度量值,而是由其他元素尺寸来决定的相对值。

    28.优雅降级和渐进增强

    渐进增强(Progressive Enhancement):一开始就针对低版本浏览器进行构建页面,完成基本的功能,然后再针对高级浏览器进行效果、交互、追加功能达到更好的体验。

    优雅降级(Graceful Degradation):一开始就构建站点的完整功能,然后针对浏览器测试和修复。比如一开始使用 CSS3 的特性构建了一个应用,然后逐步针对各大浏览器进行 hack 使其可以在低版本浏览器上正常浏览。

    其实渐进增强和优雅降级并非什么新概念,只是旧的概念换了一个新的说法。在传统软件开发中,经常会提到向上兼容向下兼容的概念。渐进增强相当于向上兼容,而优雅降级相当于向下兼容

    29.eval()的作用

    把字符串参数解析成JS代码并运行,并返回执行的结果;

    eval("2+3");//执行加运算,并返回运算值。  

    eval("varage=10");//声明一个age变量  

    eval的作用域

    functiona(){  

    1.  eval("var x=1"); //等效于 var x=1;  

    2.  console.log(x); //输出1  

    3. }  

    4. a();  

    5. console.log(x);//错误 x没有定

    30. JS哪些操作会造成内存泄露

    1)意外的全局变量引起的内存泄露

    function leak(){  

      leak="xxx";//leak成为一个全局变量,不会被回收  

    }

    2)闭包引起的内存泄露

    3)3)没有清理的DOM元素引用

    4)被遗忘的定时器或者回调 5)子元素存在引起的内存泄露

    31. 浏览器缓存有哪些,通常缓存有哪几种

    一、http缓存

    二、websql

    cookie

    localstorage

    sessionstorage

    flash缓存

    32:bootstrap响应式实现的原理

    百分比布局+媒体查询

    33.关于JS事件冒泡与JS事件代理(事件委托)

     事件作为DOM操作重要的一环,需要大家好好理解和运用,今天特意看了一下事件冒泡和事件代理的相关资料,感触颇深,也深感自己的无知不知道多浪费了多少内存,废话不多说进入正题:

    1.事件冒泡:

          通俗易懂的来讲,就是当一个子元素的事件被触发的时候(如onclick事件),该事件会从事件源(被点击的子元素)开始逐级向上传播,触发父级元素的点击事件。

    2.事件委托

        事件委托,首先按字面的意思就能看你出来,是将事件交由别人来执行,再联想到上面讲的事件冒泡,是不是想到了?对,就是将子元素的事件通过冒泡的形式交由父元素来执行。下面经过详细的例子来说明事件委托:

    有可能在开发的时候会遇到这种情况:如导航每一个栏目都要加一个事件,你可能会通过遍历来给每个栏目添加事件:

    事件委托是怎

    1. var ul = document.getElementById('parentUl');  

    2.     ul.οnclick=function (event) {  

    3.       var e = event||window.event,  

    4.               source = e.target || e.srcElement;//target表示在事件冒泡中触发事件的源元素,在IE中是srcElement  

    5.         if(source.nodeName.toLowerCase() == "li"){   //判断只有li触发的才会输出内容  

    6.             alert(source.innerHTML);  

    7.         }  

    8.         stopPropagation(e);                           //阻止继续冒泡  

    9.     };  

    10.     function addElement() {  

    11.         var li = document.createElement('li');  

    12.         li.innerHTML="我是新孩子";  

    13.         ul.appendChild(li);  

    14.     }  

    34. CSS样式覆盖规则

    规则一:由于继承而发生样式冲突时,最近祖先获胜。

    规则二:继承的样式和直接指定的样式冲突时,直接指定的样式获胜

    规则三:直接指定的样式发生冲突时,样式权值高者获胜。

    样式的权值取决于样式的选择器,权值定义如下表。

    CSS选择器

    权值

    标签选择器

    1

    类选择器

    10

    ID选择器

    100

    内联样式

    1000

    伪元素(:first-child等)

    1

    伪类(:link等)

    10

    可以看到,内联样式的权值>>ID选择器>>类选择器>>标签选择器,除此以外,后代选择器的权值为每项权值之和,比如”#nav .current a”的权值为100 + 10 + 1 = 111。

    规则四:样式权值相同时,后者获胜。

    规则五:!important的样式属性不被覆盖。

    !important可以看做是万不得已的时候,打破上述四个规则的”金手指”。如果你一定要采用某个样式属性,而不让它被覆盖的,可以在属性值后加上!important,以规则四的例子为例,”.byline a {color:red !important;}”可以强行使链接显示红色。大多数情况下都可以通过其他方式来控制样式的覆盖,不能滥用!important。

    35. 介绍一下box-sizing属性

    兼容问题 
    首先,box-sizing属性在FireFox中存在兼容问题,所以需要使用-moz-box-sizing做一下兼容。

     

    属性值

    · box-sizing:content-box

    · box-sizing:border-box

    · box-sizing:inherit

     

    content-box

    · 这是box-sizing的默认属性值

    · 是CSS2.1中规定的宽度高度的显示行为

    · 在CSS中定义的宽度和高度就对应到元素的内容框

    · 在CSS中定义的宽度和高度之外绘制元素的内边距和边框

     

    border-box

    · 在CSS中微元素设定的宽度和高度就决定了元素的边框盒

    · 即为元素在设置内边距和边框是在已经设定好的宽度和高度之内进行绘制

    · CSS中设定的宽度和高度减去边框和内间距才能得到元素内容所占的实际宽度和高度

    36. css选择符有哪些?优先级算法如何计算?(常见)

    37. 请简要描述margin重合问题,及解决方式

    1.同向margin的重叠:
    1图片的margin-top与3图片的margin-top发生重叠,2图片的margin-bottom与3图片的margin-bottom发生重叠。这时候重叠之后的margin值由发生重叠两片的最大值决定;如果其中一个出现负值,则由最大的正边距减去绝对值最大的负边距,如果没有最大正边距,则由0减去绝对值最大的负边距。
    解决同向重叠的方法:
    (1)在最外层的div中加入overflow:hidden;zoom:1
    (2)在最外层加入padding:1px;属性
    (3)在最外层加入:border:1px solid #cacbcc;
    2.异向重叠问题:
    1图片的margin-bottom与2图片的margin-top发生重叠,这时候重叠之后的margin值由发生重叠两图片的最大值的决定的。
    解决异向重叠问题:
    float:left(只能解决IE6浏览器中的异向重叠问题,可以解决IE8以上、chorme、firefox、opera下的同向重叠问题)

     

    38:position的值,relative\absolute\fixed分别相对于进行谁定位,有什么区别,什么时候用?

    39.解释下CSS sprites,以及你要如何在页面或网站中使用它。

    CSS Sprites其实就是把网页中一些背景图片整合到一张图片文件中,再利用CSS的“background-image”,“background-repeat”,“background-position”的组合进行背景定位,background-position可以用数字能精确的定位出背景图片的位置

     

    40.什么是闭包,如何使用它,为什么要使用它?

    包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成“定义在一个函数内部的函数”。

    所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。闭包可以用在许多地方。它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。

    使用闭包的注意点:

    · 由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。

    · 闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。

     

    41.请解释JSONP的工作原理,以及它为什么不是真正的AJAX。

    JSONP (JSON with Padding)是一个简单高效的跨域方式,HTML中的script标签可以加载并执行其他域的javascript,于是我们可以通过script标记来动态加载其他域的资源。例如我要从域A的页面pageA加载域B的数据,那么在域B的页面pageB中我以JavaScript的形式声明pageA需要的数据,然后在 pageA中用script标签把pageB加载进来,那么pageB中的脚本就会得以执行。JSONP在此基础上加入了回调函数,pageB加载完之后会执行pageA中定义的函数,所需要的数据会以参数的形式传递给该函数。JSONP易于实现,但是也会存在一些安全隐患,如果第三方的脚本随意地执行,那么它就可以篡改页面内容,截获敏感数据。但是在受信任的双方传递数据,JSONP是非常合适的选择。

    AJAX是不跨域的,而JSONP是一个是跨域的,还有就是二者接收参数形式不一样!

    42.请解释一下JavaScript的同源策略。

    在客户端编程语言中,如javascript和 ActionScript,同源策略是一个很重要的安全理念,它在保证数据的安全性方面有着重要的意义。同源策略规定跨域之间的脚本是隔离的,一个域的脚本不能访问和操作另外一个域的绝大部分属性和方法。那么什么叫相同域,什么叫不同的域呢?当两个域具有相同的协议, 相同的端口,相同的host,那么我们就可以认为它们是相同的域。同源策略还应该对一些特殊情况做处理,比如限制file协议下脚本的访问权限。本地的HTML文件在浏览器中是通过file协议打开的,如果脚本能通过file协议访问到硬盘上其它任意文件,就会出现安全隐患,目前IE8还有这样的隐患。

    43.怎样添加、移除、移动、复制、创建和查找节点?

     1)创建新节点

    createDocumentFragment() //创建一个DOM片段
    createElement() //创建一个具体的元素
    createTextNode() //创建一个文本节点

    2)添加、移除、替换、插入
    appendChild() //添加
    removeChild() //移除
    replaceChild() //替换
    insertBefore() //插入

    3)查找
    getElementsByTagName() //通过标签名称
    getElementsByName() //通过元素的Name属性的值
    getElementById() //通过元素Id,唯一性

    44.谈谈垃圾回收机制方式及内存管理

    回收机制方式

    1、定义和用法:垃圾回收机制(GC:Garbage Collection),执行环境负责管理代码执行过程中使用的内存。

    2、原理:垃圾收集器会定期(周期性)找出那些不在继续使用的变量,然后释放其内存。但是这个过程不是实时的,因为其开销比较大,所以垃圾回收器会按照固定的时间间隔周期性的执行。

    3、实例如下:

    function fn1() {

        var obj = {name: 'hanzichi', age: 10};

    }

    function fn2() {

        var obj = {name:'hanzichi', age: 10};

       return obj;

    }var a = fn1();var b = fn2();

    fn1中定义的obj为局部变量,而当调用结束后,出了fn1的环境,那么该块内存会被js引擎中的垃圾回收器自动释放;在fn2被调用的过程中,返回的对象被全局变量b所指向,所以该块内存并不会被释放。

     4、垃圾回收策略:标记清除(较为常用)和引用计数。

    标记清除:

      定义和用法:当变量进入环境时,将变量标记"进入环境",当变量离开环境时,标记为:"离开环境"。某一个时刻,垃圾回收器会过滤掉环境中的变量,以及被环境变量引用的变量,剩下的就是被视为准备回收的变量。

      到目前为止,IE、Firefox、Opera、Chrome、Safari的js实现使用的都是标记清除的垃圾回收策略或类似的策略,只不过垃圾收集的时间间隔互不相同。

    引用计数:

      定义和用法:引用计数是跟踪记录每个值被引用的次数。

      基本原理:就是变量的引用次数,被引用一次则加1,当这个引用计数为0时,被视为准备回收的对象。

    45、jQuery的事件委托方法bind 、live、delegate、on之间有什么区别?

    (1)、bind 【jQuery 1.3之前】

    定义和用法:主要用于给选择到的元素上绑定特定事件类型的监听函数;

    语法:bind(type,[data],function(eventObject));

    特点:

    (1)、适用于页面元素静态绑定。只能给调用它的时候已经存在的元素绑定事件,不能给未来新增的元素绑定事件。

    (2)、当页面加载完的时候,你才可以进行bind(),所以可能产生效率问题。

    实例如下:$( "#members li a" ).bind( "click", function( e ) {} );

    (2)、live 【jQuery 1.3之后】

    定义和用法:主要用于给选择到的元素上绑定特定事件类型的监听函数;

    语法:live(type, [data], fn);

    特点:

    (1)、live方法并没有将监听器绑定到自己(this)身上,而是绑定到了this.context上了。

    (2)、live正是利用了事件委托机制来完成事件的监听处理,把节点的处理委托给了document,新添加的元素不必再绑定一次监听器。

    (3)、使用live()方法但却只能放在直接选择的元素后面,不能在层级比较深,连缀的DOM遍历方法后面使用,即$(“ul”").live...可以,但$("body").find("ul").live...不行; 

    实例如下:$( document ).on( "click", "#members li a", function( e ) {} );

    (3)、delegate 【jQuery 1.4.2中引入】

    定义和用法:将监听事件绑定在就近的父级元素上

    语法:delegate(selector,type,[data],fn)

    特点:

    (1)、选择就近的父级元素,因为事件可以更快的冒泡上去,能够在第一时间进行处理。

    (2)、更精确的小范围使用事件代理,性能优于.live()。可以用在动态添加的元素上。

    实例如下:

    $("#info_table").delegate("td","click",function(){/*显示更多信息*/});

    $("table").find("#info").delegate("td","click",function(){/*显示更多信息*/});

    (4)、on 【1.7版本整合了之前的三种方式的新事件绑定机制】

    定义和用法:将监听事件绑定到指定元素上。

    语法:on(type,[selector],[data],fn)

    实例如下:$("#info_table").on("click","td",function(){/*显示更多信息*/});参数的位置写法与delegate不一样。

    说明:on方法是当前JQuery推荐使用的事件绑定方法,附加只运行一次就删除函数的方法是one()。

     总结:.bind(), .live(), .delegate(),.on()分别对应的相反事件为:.unbind(),.die(), .undelegate(),.off()

    46、px和em的区别

    相同点:px和em都是长度单位;

    异同点:px的值是固定的,指定是多少就是多少,计算比较容易。em得值不是固定的,并且em会继承父级元素的字体大小。
    浏览器的默认字体高都是16px。所以未经调整的浏览器都符合: 1em=16px。那么12px=0.75em, 10px=0.625em。

    47、浏览器的内核分别是什么?

    IE: trident内核

    Firefox:gecko内核

    Safari:webkit内核

    Opera:以前是presto内核,Opera现已改用Google Chrome的Blink内核

    Chrome:Blink(基于webkit,Google与Opera Software共同开发)

    48、什么叫优雅降级和渐进增强?

    渐进增强 progressive enhancement:
    针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。

    优雅降级 graceful degradation:
    一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。

    区别:

    a. 优雅降级是从复杂的现状开始,并试图减少用户体验的供给

    b. 渐进增强则是从一个非常基础的,能够起作用的版本开始,并不断扩充,以适应未来环境的需要

    c. 降级(功能衰减)意味着往回看;而渐进增强则意味着朝前看,同时保证其根基处于安全地带

    49、sessionStorage 、localStorage 和 cookie 之间的区别

     共同点:用于浏览器端存储的缓存数据

    不同点:

    (1)、存储内容是否发送到服务器端:当设置了Cookie后,数据会发送到服务器端,造成一定的宽带浪费;

            web storage,会将数据保存到本地,不会造成宽带浪费;

    (2)、数据存储大小不同:Cookie数据不能超过4K,适用于会话标识;web storage数据存储可以达到5M;

    (3)、数据存储的有效期限不同:cookie只在设置了Cookid过期时间之前一直有效,即使关闭窗口或者浏览器;

            sessionStorage,仅在关闭浏览器之前有效;localStorage,数据存储永久有效;

    (4)、作用域不同:cookie和localStorage是在同源同窗口中都是共享的;sessionStorage不在不同的浏览器窗口中共享,即使是同一个页面;

    50、浏览器是如何渲染页面的?

    渲染的流程如下:

    1.解析HTML文件,创建DOM树。

       自上而下,遇到任何样式(link、style)与脚本(script)都会阻塞(外部样式不阻塞后续外部脚本的加载)。

    2.解析CSS。优先级:浏览器默认设置<用户设置<外部样式<内联样式<HTML中的style样式;

    3.将CSS与DOM合并,构建渲染树(Render Tree)

    4.布局和绘制,重绘(repaint)和重排(reflow)

    51:js的基本数据类型

    JavaScript中有五种基本数据类型,它们分别是:undefined,null,boolean,number,string。

    还有一种复杂数据类型-object。 

    52:事件委托

    事件委托就是利用的DOM事件的事件捕获阶段。把具体dom上发生的事件,委托给更大范围的dom去处理。好比送信员,如果每次都把信件送给每一户,非常繁琐。但是如果交给一个大范围的管理者,比如小区的传达室,那么事情会变得非常简单。事件委托就类似这种原理,我页面中有很多按钮,如果不使用事件委托,我只能在每个按钮上注册事件。非常麻烦。但如果我把事件注册在一个大范围的div(假设所有的按钮都在这个div中),那么我只要注册一次事件,就可以处理所有按钮(只要按钮包含在上述div中)事件的响应了

    53:CSS3新增了很多的属性,下面一起来分析一下新增的一些属性:

    1.CSS3边框:

    · border-radius:CSS3圆角边框。在 CSS2 中添加圆角矩形需要技巧,我们必须为每个圆角使用不同的图片,在 CSS3 中,创建圆角是非常容易的,在 CSS3 中,border-radius 属性用于创建圆角。border:2px solid;

    · box-shadow:CSS3边框阴影。在 CSS3 中,box-shadow 用于向方框添加阴影。box-shadow:10px 10px 5px #888888;

    · border-image:CSS3边框图片。通过 CSS3 的 border-image 属性,您可以使用图片来创建边框。border-image:url(border.png) 30 30 round;

    2.CSS3背景:

    · background-size: 属性规定背景图片的尺寸。在 CSS3 之前,背景图片的尺寸是由图片的实际尺寸决定的。在 CSS3 中,可以规定背景图片的尺寸,这就允许我们在不同的环境中重复使用背景图片。您能够以像素或百分比规定尺寸。如果以百分比规定尺寸,那么尺寸相对于父元素的宽度和高度。

    · background-origin :属性规定背景图片的定位区域。背景图片可以放置于 content-box、padding-box 或 border-box 区域。

    3.CSS3文字效果:

    · text-shadow:在 CSS3 中,text-shadow 可向文本应用阴影。text-shadow:5px 5px 5px #FFFFFF;

    · word-wrap :单词太长的话就可能无法超出某个区域,允许对长单词进行拆分,并换行到下一行:p{word-wrap:break-word;}

    4.CSS3 2D转换:

    transform:通过 CSS3 转换,我们能够对元素进行移动、缩放、转动、拉长或拉伸。

    · translate():元素从其当前位置移动,根据给定的 left(x 坐标) 和 top(y 坐标) 位置参数:transform:translate(50px,100px);值 translate(50px,100px) 把元素从左侧移动 50 像素,从顶端移动 100 像素。

    · rotate():元素顺时针旋转给定的角度。允许负值,元素将逆时针旋转。transform:rotate(30deg);值 rotate(30deg) 把元素顺时针旋转 30 度。

    · scale():元素的尺寸会增加或减少,根据给定的宽度(X 轴)和高度(Y 轴)参数:transform:scale(2,4);值 scale(2,4) 把宽度转换为原始尺寸的 2 倍,把高度转换为原始高x() 5.CSS3 3D转换:

    · rotateX():元素围绕其 X 轴以给定的度数进行旋转。transform:rotateX(120deg);

    · rotateY():元素围绕其 Y 轴以给定的度数进行旋转。transform:rotateY(120deg);

    6.CSS3 过渡:当元素从一种样式变换为另一种样式时为元素添加效果。

    7.CSS3动画:通过 CSS3,我们能够创建动画,这可以在许多网页中取代动画图片、Flash 动画以及 JavaScript。

    8.CSS3多列:

    · column-count:属性规定元素应该被分隔的列数。

    · column-gap:属性规定列之间的间隔。

    · column-rule :属性设置列之间的宽度、样式和颜色规则。

    9.CSS3用户界面:

    · resize:属性规定是否可由用户调整元素尺寸。

    · box-sizing:属性允许您以确切的方式定义适应某个区域的具体内容。

    · outline-offset :属性对轮廓进行偏移,并在超出边框边缘的位置绘制轮廓。

    54:从输入url到显示页面,都经历了什么

    第一步:客户机提出域名解析请求,并将该请求发送给本地的域名服务器。

    第二步:当本地的域名服务器收到请求后,就先查询本地的缓存,如果有该纪录项,则本地的域名服务器就直接把查询的结果返回。

    第三步:如果本地的缓存中没有该纪录,则本地域名服务器就直接把请求发给根域名服务器,然后根域名服务器再返回给本地域名服务器一个所查询域(根的子域)的主域名服务器的地址。
    第四步:本地服务器再向上一步返回的域名服务器发送请求,然后接受请求的服务器查询自己的缓存,如果没有该纪录,则返回相关的下级的域名服务器的地址。
    第五步:重复第四步,直到找到正确的纪录

    2种解释:

    一般会经历以下几个过程:

    1、首先,在浏览器地址栏中输入url

    2、浏览器先查看浏览器缓存-系统缓存-路由器缓存,如果缓存中有,会直接在屏幕中显示页面内容。若没有,则跳到第三步操作。

    3、在发送http请求前,需要域名解析(DNS解析)(DNS(域名系统,Domain Name System)是互联网的一项核心服务,它作为可以将域名和IP地址相互映射的一个分布式数据库,能够使人更方便的访问互联网,而不用去记住IP地址。),解析获取相应的IP地址。

    4、浏览器向服务器发起tcp连接,与浏览器建立tcp三次握手(TCP即传输控制协议。TCP连接是互联网连接协议集的一种。)

    5、握手成功后,浏览器向服务器发送http请求,请求数据包

    6、服务器处理收到的请求,将数据返回至浏览器

    7、浏览器收到HTTP响应

    8、读取页面内容,浏览器渲染,解析html源码

    9、生成Dom树、解析css样式、js交互

    10、客户端和服务器交互

    11、ajax查询

    55:对<meta></meta>标签有什么理解

    什么是meta标签?

    引自下W3school的定义说明一下。

    元数据(metadata)是关于数据的信息。

    标签提供关于 HTML 文档的元数据。元数据不会显示在页面上,但是对于机器是可读的。

    典型的情况是,meta 元素被用于规定页面的描述、关键词、文档的作者、最后修改时间以及其他元数据。

    标签始终位于 head 元素中。

    元数据可用于浏览器(如何显示内容或重新加载页面),搜索引擎(关键词),或其他 web 服务。

    其实对上面的概念简单总结下就是:<meta> 标签提供关于 HTML 文档的元数据。它不会显示在页面上,但是对于机器是可读的。可用于浏览器(如何显示内容或重新加载页面),搜索引擎(关键词),或其他 web 服务。

    meta的作用

    meta里的数据是供机器解读的,告诉机器该如何解析这个页面,还有一个用途是可以添加服务器发送到浏览器的http头部内容

    56:new操作符到底到了什么

    先看代码

    [javascript] view plain copy

    1. var Func=function(){  

    2. };  

    3. var func=new Func ();  

    new共经过了4几个阶段

    1、创建一个空对象

    [javascript] view plain copy

    1. varobj=new Object();  

    2、设置原型链

    [javascript] view plain copy

    1. obj.__proto__= Func.prototype;  

    3、让Func中的this指向obj,并执行Func的函数体。

    [javascript] view plain copy

    1. var result =Func.call(obj);  

    4、判断Func的返回值类型:

    如果是值类型,返回obj。如果是引用类型,就返回这个引用类型的对象。

    [javascript] view plain copy

    1. if (typeof(result) == "object"){  

    2.   func=result;  

    3. }  

    4. else{  

    5.     func=obj;;  

    6. }  

    57:h5新特性

    HTML5新特性 —— 新特性
    (1)新的语义标签和属性
    (2)表单新特性
    (3)视频和音频
    (4)Canvas绘图
    (5)SVG绘图
    (6)地理定位
    (7)拖放API
    58:vue的生命周期

     

     

    58:请写出你对闭包的理解,并列出简单的理解

    使用闭包主要是为了设计私有的方法和变量。闭包的优点是可以避免全局变量的污染,缺点是闭包会常驻内存,会增大内存使用量,使用不当很容易造成内存泄露。

    闭包有三个特性:

    1.函数嵌套函数 

    2.函数内部可以引用外部的参数和变量 

    3.参数和变量不会被垃圾回收机制回收

     

    59:display none visibility hidden区别?

    1.display:none是彻底消失,不在文档流中占位,浏览器也不会解析该元素;visibility:hidden是视觉上消失了,可以理解为透明度为0的效果,在文档流中占位,浏览器会解析该元素;

    2.使用visibility:hidden比display:none性能上要好,display:none切换显示时visibility,页面产生回流(当页面中的一部分元素需要改变规模尺寸、布局、显示隐藏等,页面重新构建,此时就是回流。所有页面第一次加载时需要产生一次回流),而visibility切换是否显示时则不会引起回流。

    60:JavaScript中如何检测一个变量是一个String类型?请写出函数实现

    typeof(obj) === "string"

    typeof obj === "string"

    obj.constructor === String

    61:如何理解闭包?

    1、定义和用法:当一个函数的返回值是另外一个函数,而返回的那个函数如果调用了其父函数内部的其它变量,如果返回的这个函数在外部被执行,就产生了闭包。

    2、表现形式:使函数外部能够调用函数内部定义的变量。

    3、实例如下:

    (1)、根据作用域链的规则,底层作用域没有声明的变量,会向上一级找,找到就返回,没找到就一直找,直到window的变量,没有就返回undefined。这里明显count 是函数内部的flag2 的那个count 。

    var count=10;   //全局作用域 标记为flag1function add(){

        var count=0;    //函数全局作用域 标记为flag2

        return function(){

            count+=1;   //函数的内部作用域        alert(count);

        }

    }var s = add()

    s();//输出1

    s();//输出2

    4、变量的作用域

    要理解闭包,首先必须理解Javascript特殊的变量作用域。

    变量的作用域分类:全局变量和局部变量。

    特点:

    1、函数内部可以读取函数外部的全局变量;在函数外部无法读取函数内的局部变量。

    2、函数内部声明变量的时候,一定要使用var命令。如果不用的话,你实际上声明了一个全局变量!

     5、使用闭包的注意点

    1)滥用闭包,会造成内存泄漏:由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。

    2)会改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。

    62:谈谈垃圾回收机制方式及内存管理

    回收机制方式

    1、定义和用法:垃圾回收机制(GC:Garbage Collection),执行环境负责管理代码执行过程中使用的内存。

    2、原理:垃圾收集器会定期(周期性)找出那些不在继续使用的变量,然后释放其内存。但是这个过程不是实时的,因为其开销比较大,所以垃圾回收器会按照固定的时间间隔周期性的执行。

    3、实例如下:

    function fn1() {

        var obj = {name: 'hanzichi', age: 10};

    }

    function fn2() {

        var obj = {name:'hanzichi', age: 10};

       return obj;

    }var a = fn1();var b = fn2();

    fn1中定义的obj为局部变量,而当调用结束后,出了fn1的环境,那么该块内存会被js引擎中的垃圾回收器自动释放;在fn2被调用的过程中,返回的对象被全局变量b所指向,所以该块内存并不会被释放。

     4、垃圾回收策略:标记清除(较为常用)和引用计数。

    标记清除:

      定义和用法:当变量进入环境时,将变量标记"进入环境",当变量离开环境时,标记为:"离开环境"。某一个时刻,垃圾回收器会过滤掉环境中的变量,以及被环境变量引用的变量,剩下的就是被视为准备回收的变量。

      到目前为止,IE、Firefox、Opera、Chrome、Safari的js实现使用的都是标记清除的垃圾回收策略或类似的策略,只不过垃圾收集的时间间隔互不相同。

    引用计数:

      定义和用法:引用计数是跟踪记录每个值被引用的次数。

      基本原理:就是变量的引用次数,被引用一次则加1,当这个引用计数为0时,被视为准备回收的对象。

    63:判断一个字符串中出现次数最多的字符,统计这个次数

    var str = 'asdfssaaasasasasaa';

    var json = {};

    for (var i = 0; i < str.length; i++) {

        if(!json[str.charAt(i)]){

           json[str.charAt(i)] = 1;

        }else{

           json[str.charAt(i)]++;

        }

    };var iMax = 0;var iIndex = '';for(var i in json){

        if(json[i]>iMax){

             iMax = json[i];

             iIndex = i;

        }

    }        console.log('出现次数最多的是:'+iIndex+'出现'+iMax+'次');

    64、$(document).ready()方法和window.onload有什么区别?

     (1)、window.onload方法是在网页中所有的元素(包括元素的所有关联文件)完全加载到浏览器后才执行的。

     (2)、$(document).ready() 方法可以在DOM载入就绪时就对其进行操纵,并调用执行绑定的函数。

    65、 jquery中$.get()提交和$.post()提交有区别吗?

    相同点:都是异步请求的方式来获取服务端的数据;

    异同点:

    1、请求方式不同:$.get() 方法使用GET方法来进行异步请求的。$.post() 方法使用POST方法来进行异步请求的。

    2、参数传递方式不同:get请求会将参数跟在URL后进行传递,而POST请求则是作为HTTP消息的实体内容发送给Web服务器的,这种传递是对用户不可见的。

    3、数据传输大小不同:get方式传输的数据大小不能超过2KB 而POST要大的多

    4、安全问题: GET 方式请求的数据会被浏览器缓存起来,因此有安全问题。

    66、jQuery的事件委托方法bind 、live、delegate、on之间有什么区别?(常见)

    (1)、bind 【jQuery 1.3之前】

    定义和用法:主要用于给选择到的元素上绑定特定事件类型的监听函数;

    语法:bind(type,[data],function(eventObject));

    特点:

    (1)、适用于页面元素静态绑定。只能给调用它的时候已经存在的元素绑定事件,不能给未来新增的元素绑定事件。

    (2)、当页面加载完的时候,你才可以进行bind(),所以可能产生效率问题。

    实例如下:$( "#members li a" ).bind( "click", function( e ) {} );

    (2)、live 【jQuery 1.3之后】

    定义和用法:主要用于给选择到的元素上绑定特定事件类型的监听函数;

    语法:live(type, [data], fn);

    特点:

    (1)、live方法并没有将监听器绑定到自己(this)身上,而是绑定到了this.context上了。

    (2)、live正是利用了事件委托机制来完成事件的监听处理,把节点的处理委托给了document,新添加的元素不必再绑定一次监听器。

    (3)、使用live()方法但却只能放在直接选择的元素后面,不能在层级比较深,连缀的DOM遍历方法后面使用,即$(“ul”").live...可以,但$("body").find("ul").live...不行; 

    实例如下:$( document ).on( "click", "#members li a", function( e ) {} );

    (3)、delegate 【jQuery 1.4.2中引入】

    定义和用法:将监听事件绑定在就近的父级元素上

    语法:delegate(selector,type,[data],fn)

    特点:

    (1)、选择就近的父级元素,因为事件可以更快的冒泡上去,能够在第一时间进行处理。

    (2)、更精确的小范围使用事件代理,性能优于.live()。可以用在动态添加的元素上。

    实例如下:

    $("#info_table").delegate("td","click",function(){/*显示更多信息*/});

    $("table").find("#info").delegate("td","click",function(){/*显示更多信息*/});

    (4)、on 【1.7版本整合了之前的三种方式的新事件绑定机制】

    定义和用法:将监听事件绑定到指定元素上。

    语法:on(type,[selector],[data],fn)

    实例如下:$("#info_table").on("click","td",function(){/*显示更多信息*/});参数的位置写法与delegate不一样。

    说明:on方法是当前JQuery推荐使用的事件绑定方法,附加只运行一次就删除函数的方法是one()。

     总结:.bind(), .live(), .delegate(),.on()分别对应的相反事件为:.unbind(),.die(), .undelegate(),.off()

    67、px和em的区别(常见)

     

    相同点:px和em都是长度单位;

    异同点:px的值是固定的,指定是多少就是多少,计算比较容易。em得值不是固定的,并且em会继承父级元素的字体大小。
    浏览器的默认字体高都是16px。所以未经调整的浏览器都符合: 1em=16px。那么12px=0.75em, 10px=0.625em。

    68、浏览器的内核分别是什么?

    IE: trident内核

    Firefox:gecko内核

    Safari:webkit内核

    Opera:以前是presto内核,Opera现已改用Google Chrome的Blink内核

    Chrome:Blink(基于webkit,Google与Opera Software共同开发)

    69、什么叫优雅降级和渐进增强?(常见)

    渐进增强 progressive enhancement:
    针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。

    优雅降级 graceful degradation:
    一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。

    区别:

    a. 优雅降级是从复杂的现状开始,并试图减少用户体验的供给

    b. 渐进增强则是从一个非常基础的,能够起作用的版本开始,并不断扩充,以适应未来环境的需要

    c. 降级(功能衰减)意味着往回看;而渐进增强则意味着朝前看,同时保证其根基处于安全地带

    70、sessionStorage 、localStorage 和 cookie 之间的区别(常见)

     共同点:用于浏览器端存储的缓存数据

    不同点:

    (1)、存储内容是否发送到服务器端:当设置了Cookie后,数据会发送到服务器端,造成一定的宽带浪费;

            web storage,会将数据保存到本地,不会造成宽带浪费;

    (2)、数据存储大小不同:Cookie数据不能超过4K,适用于会话标识;web storage数据存储可以达到5M;

    (3)、数据存储的有效期限不同:cookie只在设置了Cookid过期时间之前一直有效,即使关闭窗口或者浏览器;

            sessionStorage,仅在关闭浏览器之前有效;localStorage,数据存储永久有效;

    (4)、作用域不同:cookie和localStorage是在同源同窗口中都是共享的;sessionStorage不在不同的浏览器窗口中共享,即使是同一个页面;

     

    展开全文
  • 互联网金融(ITFIN)就是互联网技术和金融功能的有机结合,依托大数据和云计算在开放的互联网平台上形成的功能化金融业态及其服务体系,包括基于网络平台的金融市场体系、金融服务体系、金融组织体系、金融产品体系...
  •  当日晚间,谷歌一家区域代理商负责人收到了谷歌中国的电子邮件,邮件转自Google美国总部,表示该代理可继续为中国用户提供互联网搜索和其 他服务。“谷歌能续期当然很好,就像是在最后关头接上了一口氧气吧...
  • 做市选择并设计市场规则以实现某些目标,例如在一个卖方和多个买方的情况下,从销售中获得最大收益。 给定这样的规则,市场参与者可能会相互竞争,以最大化其在所购商品上的效用函数值,这可能是通过隐藏或错误地...
  • 银行卡收单____商户费率_代理商分润

    千次阅读 2017-11-08 16:53:34
    比如支付宝的互联网支付(快捷支付)直连银行就是这么干的。 楼主提到:市面上的第三方支付公司的pos机费率有很多种,比如0.38、0.4、0.5等等。 这个其实也简单,有一可能就是第三方非金机构直连银行,pos刷卡...
  • SDN

    千次阅读 多人点赞 2017-06-29 11:35:37
    包过滤,应用代理,状态监测防火墙 ;根据产品形态,可以分为软件和硬件防火墙。 解决网络拥塞 -> 流量控制 网络拥塞一直是传统网络中的永恒问题,从TCP的流量控制机制:滑动窗口,防止小包,慢启动拥塞...
  • JAVA上百实例源码以及开源项目

    千次下载 热门讨论 2016-01-03 17:37:40
    百度云盘分享 简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级、中级、高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情、执着,对...
  • 它将允许业主为物业做广告,客户可以访问可用的出租物业,帮助代理商将客户与物业联系起来并准备租约。 客户将能够查看房产、安排参观和申请租赁。 OPR 将包含一个数据库,其中包含有关房产的信息,包括照片和租金...
  • 商代理分销系统

    千次阅读 2015-07-21 13:44:47
    微云基石微商代理分销系统TM(简称:微商代理分销系统TM),是所有微分销系统中第一个采用二级无限分销模式的系统,两级分销比例由商家设定,系统自动记录追踪用户IP并管理成为分销的前后层级。移动互联网的泛...
  • 下面说一下为什么线下渠道不好做的原因 1运营商对渠道掌控力其实没有想象的那么强大部分渠道掌控在各大代理商 手中代理商分散 2代理商的业务是卖手机营业员每卖一台手机提成一般会有 50-200 元比 做应用这业务简单多...
  • 2018年四大爬虫代理IP提供对比

    千次阅读 2018-10-06 15:06:08
    但目前互联网上提供商业代理IP服务的提供又有许多,这里选择三个具有代表性的代理IP提供作为评测对象。 备注: 为了对比付费代理IP和免费代理IP的差异,这里添加了免费代理IP提供 - 西刺代理作为对比。 各个...
  • 精确IP定位

    千次阅读 2020-01-21 15:29:36
    IP定位是一种非常广泛的定位手段。虽然现在GPS定位和Wifi、基站定位技术已经很成熟了,但是在获取不到上述信息的情况下仍然需要依赖...普通的IP定位在互联网上有很多公共的服务API,各个大公司也都有自己的IP库,比...
  • 互联网房地产行业发展报告中国互联网+房地产产业现状传统房地产+互联网产业生态图谱参与企业构成复杂处于自由竞争状态开发导流交易媒体|信息|电商开发营销代理一二手联动二手房长租房传统房地产+互联网产业生态...
  • 请检查您的互联网连接 一般情况下您会使用代理 后面还有一堆文字bulabula的,迷惑的不行,于是乎,我就把teamview关了,重新打开exe,oh,no,竟然打不开了。打开任务管理器后,发现这家伙还存活着呢!果断强制关闭...
  • 中国互联网+房地产产业现状 传统房地产+互联网产业生态图谱 参与企业构成复杂处于自由竞争状态 开发 导流 交易 开发 营销代理 一二手联动 媒体|信息|电商 二手房 长租房 传统房地产+互联网产业生态图谱 ...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 42,520
精华内容 17,008
关键字:

互联网代理商