zoukankan      html  css  js  c++  java
  • Web开发过程中要注意的问题 [转]

    1,document.getElementById方法只能获取到一个对象,即使有多个同名的对象,也只取第 一个具有该名称的对象,例如在一个form(名称为myform)中,有三个id="mycheckbox"的复选框,那么使用 document.getElementById("mycheckbox"),返回的是第一个checkbox对象,而不是返回一个数组,如果使用 document.myform.mycheckbox则返回一个数组。

    2,使 用showModalDialog打开一个页面,则在这个页面中,对于任何链接和任何表单提交,都会在新的窗口中执行,即使你在链接或form中指定了 target="_self"也是没有用的。例如使用showModalDialog打开一个test.html,在该页面有一段代码
    <a href="test2.html" target="_seft">打开</a>
    如果点击该链接,那么将会在新窗口中打开test2.html,至少在ie中是这样的,那么是不是就没有办法解决了呢?不是的,我们可以通过在弹出的页面的head中加入下面的代码来解决这个问题:
    <head>
    <base target="_self">
    </head>

    3,在 一个页面含有某个iframe,其id="myframe" name="myframe",此时使用document.getElementById("myframe")取到的是iframe标签对象,通过该对 象可以获取iframe的各个属性,例如src、frameborder、style等等,但是不能获取到iframe所包含的子页面的各个对象。如果使 用document.frames("myframe")取到的是iframe组件对象,通过该对象可以获取到iframe所包含的页面的子页面的各个对 象,例如子页面的window对象,但是不能获得iframe标签得各个属性,例如上面说到的src等等。请参看如下类似代码:
    1.html
    <script>
    function check(){
        var obj1=document.getElementById("myframe");
        alert(obj1.src);
        //alert(obj1.window.document.myform.username.value);//Error
        var obj2=document.frames("myframe");
        alert(obj2.window.document.myform.username.value);
        //alert(obj2.src);//Error
    }
    </script>
    <body onload="check()">
    <iframe id="myframe" name="myframe" src="2.html" frameborder="3" style="300;height:200;border-1;border-color:red;border-style:solid"></iframe>
    </body>
    2.html
    <body>
    <form name="myform">
        用户名:<input type="text" name="username" value="test" />
    </form>
    </body>

    4,在table 中,如果在table中加入border="1" bordercolor="red",那么table中所有单元格都会加上厚度为1的红色边框,但是如果在table中加入css style="border-1;border-color:red;border-style:solid" 那么只会在整个table的最外面加上厚度为1的红色边框,分别如下图所示:

    当然第一个出现了双边框,这是因为没有设置cellspacing的缘故,只要在table中设计cellspacing="0",那么就变为单边框了。

    5,当有多个同名name时比如
    <span id="a1" name="a1" >显示的文件</span>
    <span id="a1" name="a1">显示2的文件</span>
    使用:var spans=document.all('a1');或者var spans=document.all.a1;
    for(i=0;i<spans.length;i++){
    alert(spans[i].innerText);
    }
    注意:必须写同名的id,不然会提示length为空.同时name:a1必须为多个,只有一个只能使用getElementID

    6,固定Table宽度.table或div里显示文章的时候,如果是汉字,文章会根据table和div的width属性自动分行,但如果是英文,当单词长度超过table或div宽度的时候,table/div便会被撑开,有时候会造成页面很难看,这时可以给table/div设置如下样式:word-break:break-all; word-wrap:break-word; 单词超长的时候能够自动截断单词分行,避免上述情况的发生。
    完整的表达如下:
    table {
    table-layout: fixed;
    word-wrap:break-word;
    }
    div {
    word-wrap:break-word;
    }

    语法:table-layout : auto | fixed
    auto : 默认值。默认的自动算法。布局将基于各单元格的内容。表格在每一单元格内所有内容读取计算之后才会显示出来
    fixed : 固定布局的算法。在这种算法中,表格和列的宽度取决于 col 对象的宽度总和,假如没有指定,则会取决于第一行每个单元格的宽度。假如表格没有指定宽度( width )属性,则表格被呈递的默认宽度为 100% 。

    语法:word-wrap是控制换行的。
    使用break-word时,是将强制换行。中文没有任何问题,英文语句也没问题。但是对于长串的英文,就不起作用。

    语法:break-word是控制是否断词的。
    normal是默认情况,英文单词不被拆开。
    break-all,是断开单词。在单词到边界时,下个字母自动到下一行。主要解决了长串英文的问题。
    keep-all,是指Chinese, Japanese, and Korean不断词。即只用此时,不用word-wrap,中文就不会换行了。(英文语句正常。)

    7,在一个网页中如何最小化窗口,当然你可能会说,网页的右上角不是有最小 化、最大化和关闭三个按钮吗,当然了这里说这个问题是指,如果不点击网页右上角的最小化,如何实现网页的最小化操作,例如有些项目中,用户需要办公界面是 全屏化的,这意味着网页自己提供的许多操作都不可见,更不用说去操作了。在网络上我们搜索最小化的解决方式,我们会发现千篇一律的使用如下的方式实现:
    <object id=hh1 classid="clsid:ADB880A6-D8FF-11CF-9377-00AA003B7A11">
    <param name="Command" value="Minimize"></object>
    <input type=button value=最小化 onclick=hh1.Click()>
    在win98 和windows2000中这个方式可能是可以的,但是在windows XP中却是不再支持了,不仅如此在windows XP中对javascript不少函数做了限制。那么在XP中如何实现最小化呢,一个可以实现的方式就是自己写一个activeX控件,这个是在项目中证 明可以实现的。(不要认为activeX控件很难写,也不要以为activeX控件用户不接受,在实际的项目中如果用户使用的都是ie,那么用户一般是会 接受的,当然这里的项目最好是内网办公项目,对于公网项目来说,用户接不接受就很难说了)

    8,注 意td中nowrap的使用,这个属性是很有用的,例如如果一个td中含有多张图片,那么如果不加入nowrap,那么很可能这些图片会由于其它的td的 挤压而产生细微的上下错位,这表现的页面上就是某处出现了一条横向的细缝。这一点很重要,页面中许多非常奇怪的现象都与此有关。

    9,对 于showModalDialog弹出的页面,不能使用右键菜单,也不支持F5和ctrl+r刷新,如果此时修改弹出页面的内容,那么必须关闭该窗口,然 后重新弹出才可以。另外,对于许多web服务器,由于服务器都设置有缓存,如果修改了弹出页面的内容,那么许多时候只是关闭弹出页面还是不够的,往往还需 要关闭弹出该页面的那个页面才可以。在这里多说一句,web开发许多奇怪的页面现象都和web服务器的缓存有着很大的关系,因此出现问题时考虑一下是否是 由于服务器的缓存所致。

    10,我们喜欢在form中定义 onsubmit操作,主要是为了在表单提交之前可以做一些有意义的操作,例如检查输入域的有效性等等,但是一定要注意,如果我们通过点击该form中的 submit按钮(type=submit或type=image)提交表单,那么该onsubmit操作会被执行,但是如果通过 document.formName.submit()提交表单,那么此onsubmit操作将不被执行。

    11,许 多时候我们修改了页面的内容,但是我们刷新页面或重新打开该页面,却看不到修改的效果,除了前面提到过的showModalDialog和缓存的情况要考 虑外,还要检查一下是否改对了地方,即你修改的那个页面是否是服务器上的那个页面,有可能你修改了其它地方的一个页面,如果不是这个原因,那么再进行其它 方面的检查。

    12,在没有系统规划好之前,请不要在css中定义html标签的统一行为,即下面的形式:
    <style>
    TABLE{font-size:11pt;color:black;}
       INPUT{border-1;border-color:pink;border-style:solid}
    </style>
    因 为一但定义了这些标签的属性,那么这将会影响页面中所有的这些标签属性,尤其在一些公用的css文件中,尽量不要定义html标签的统一行为。当然如果经 过了系统的良好的规划,那么这样做将是非常好的,只是在国内在css上经过良好规划的并不多,因此虽然我们见到许多项目和产品中对html标签做了许多 css的定义,但是真正起到作用的并不多。

    13,在html 标签中有许多属性的名称都是复合词,例如borderColor、frameBorder、readOnly等等,注意这些复合词在html的书写,一般 来说我们在html标签中写为borderColor和bordercolor,各个浏览器的解析都会通过,但是我们在使用javascriopt引用这 些属性时却需要注意了,一定使用正确的属性名称,严格来说,对于复合词而言,除了第一个有意义的词之外,其它任何有意义的词的首字母都要大写,例如对于上 面列出的三个属性的引用,一定要使用borderColor、frameBorder、readOnly的形式。
    <input type="text" id="myinput" readonly />
    <script>
        var flag=document.getElementById("myinput").readOnly;//正确的方式
        //var flag=document.getElementById("myinput").readonly;//错误的方式
    </script>

    14,我 们知道当使用浏览器的菜单“查看”->“文字大小”来改变文字的显示时(或者有些浏览器也可以使用ctrl+滚轮键),网页中的文字的字号会发生相 应的变化,如果我们在网页中的文字块中定义了style="font-size:10pt",那么这些文字块中的文字的大小将是固定的了(注意在< font/>标签定义size属性是不能固定字号的),我想这一点多数人都应该知道的。但是我们使用中有时会出现一种非常奇怪的现象,例如下面的一 段代码:
    <table><tr><td>
    <div style="font-size:10pt;border-1;border-color:red;border-style:solid">
    这是上面
    </div>
    <br />
    <div style="font-size:10pt;border-1;border-color:green;border-style:solid">
    这是下面
    </div>
    </td></tr></table>
    我们看一下在字号显示“最大”和“最小”下的差别:

    从 上图我们可以看到字号我们是固定住了,但是table的高度却会随着查看方式的不同而发生变化,这是为什么呢?原因就在于td当中的那个<br />,我们知道<br />是表示段内换行,但是要注意在网页中所谓的行也是有一定的默认高度的,而且这个高度随着查看方式的不同而发生相应的变化,因此如果我们想固定上 面table的高度不发生变化,有下面两种方式:
    方式一:在table标签中加入字号限制例如<table style="font-size:10pt"...
    方式二:在<br />中加入字号限制例如<br style="font-size:10pt" />...
    如果你是一个web开发人员,你可以试着使用ctrl+滚轮键改变网页查看文字的大小,你会发现不少页面都存在这个问题的。

    15,网页中定位对象的方式有许多种,下面先简单总结一下,以后再专门写这个方面的文章的:
    1)页面内通用定位方式(这些定位方式适用于后面其它元素的定位)
    document.getElementById(objId);//通过对象的id获取对象,这个是各个浏览器都支持的,返回一个对象
    document.getElementsByName(objName);//通过对象的name获取对象,这个是各个浏览器都支持的,返回一个数组
    document.getElementsByTagName(tagName);//通过标签名称获取对象,这个是各个浏览器都支持的,返回一个数组
    document.all.objId;//通过对象id获取对象,这个是ie支持的,返回一个对象
    document.all(objId);//通过对象id获取对象,这个是ie支持的,返回一个对象
    document.layers.objId;//通过对象id获取对象,这是Netscape支持的,返回一个对象
    document.layers(objId);//通过对象id获取对象,这是Netscape支持的,返回一个对象
    window.objName;//通过对象名称获取对象,至少在ie中如此
    objName;//通过对象名称获取对象,至少在ie中如此
    2)页面内集合元素的定位方式
    我们知道在页面中有许多集合,例如form、frame、image等等,引用这些集合中某个对象的方式为,举其中一个为例,其它都差不多,以form为例:
    document.formName;//通过表单name获取表单对象
    document.forms[index];//通过索引获取表单对象,浏览器会按顺序将页面中所有的表单集合城数组,可以通过下标引用
    document.forms(formName);//通过表单name获取表单对象
    3)定位子窗口的方式(定位子窗口对象,不是标签对象,见前面3中的说明)
    子窗口是指页面中frame或iframe窗口,定位方式为:
    document.frames[index];//索引定位方式
    document.frames(frameName);//通过名称定位
    window.frameName;//通过名称定位
    frameName;//直接通过名称来定位
    4)在子定位父窗口的方式
    通过关键字parent来引用即可,同理parent.parent则表示父父窗口,top则表示最上层窗口。
    5)原窗口定位open弹出窗口的方式,例如下面代码:
    window.open("test.html");
    这里我们要知道window.open将会返回一个弹出窗口的句柄,即可以如下:
    var owin=window.open("test.html");
    owin即代码弹出窗口对象,通过改对象可以引用到弹出窗口的各个对象。
    6)原窗口定位showModalDialog弹出窗口的方式,例如:
    window.showModalDialog("test.html");
    注 意showModalDialog与open不同,open弹出窗口后,window.open后面的代码可以继续执行,而 showModalDialog弹出窗口后,原页面被阻塞,即window.showModalDialog后面的代码不被执行,直到用户关闭了弹出窗口 才会继续往下执行,但这时因为已经关闭了弹出窗口,所以已经无法再对该窗口进行引用。
    7)open弹出的窗口对原窗口的定位方式,这个我们一般都知道,在弹出窗口中使用opener即可。
    8)showModalDialog弹出的窗口对原窗口的定位方式,这个不是使用opener,而应该在弹出窗口中使用parent。

    16,编 写页面代码尽量使用标准的html、css和javascript,不要以为只要在ie上通过就可以了,要注意最近浏览器市场已经开始发生变化了,不知道 你是否听说过Firefox2.0,它的用户量已经不在ie之下了,至少你的代码要在ie和Firefox上都通过才可以,另外现在linux越来越吃 香,保不准几年后我们的许多客户都开始使用linux,到那个时候,我们将不得不对原来已经完成的项目进行维护,与其这样的后果,还不如从现在开始就使用 标准为好,不要认为跨浏览器是很虚的话题,觉得没有必要,要知道这已经不是几年前了,现在形式和市场都在发生变化,我们的思想也该变一变了。

    17,一段文本的首行文本缩进两个汉字,这是中文段落的格式要求,我们可以通过在首行加入多个&nbsp;来实现,不过还是建议使用css的标准属性text-indent,例如下面的代码:
    <p style="text-indent:28;font-size:10pt">
    这是一段文本,请注意它的格式,<br>
    你看到了什么效果?如果你看到首行<br>
    缩进了,那么说明起作用了。
    </p>
    显示效果如下:

    18,图标与文字的配比要合适,这不仅要求图标能够正确显示文字的意思,而且还要求图标不能盖过文字的显示与含义,即图标太显眼而文字无足轻重的情况需要避免,例如下面的情况就是不太合适的:
    用户管理
    之所以不合适,主要是因为图标的含义与用户管理关系不大,图标的含义更接近“XX编辑”的意思,和用户管理基本没有什么联系。

    19,在用户登录和表单处理页面,我们要处理用户按enter键的情况,即用户按enter键也要触发提交事件,不要只有用户点击“登录”或“提交”按钮才触发提交操作。

    20,如果我们在页面中使用<a />标签,那么默认情况,当鼠标移到该链接时,鼠标自动会变为手的形状,许多时候我们希望鼠标移动到其它非链接的区域,也希望鼠标变为手的形状,我们一般的处理方式为在该区域的style中加入cursor属性,如下:
    <span style="cursor:hand" onclick="myfunc()">下一页</span>
    或者使用:
    <span style="cursor:url('http://webme.bokee.com/inc/mouse118.cur')" onclick="myfunc()">下一页</span>
    但是要注意,只有在ie中才支持cursor:hand,在firefox2.0中的cursor中是没有hand的,像wait、help等都是支持的,另外firefox中也不支持cursor:url方式。

    21,我们有时想通过javascript进行跨域页面的调用,不过出于安全性的考虑,各个浏览器一般都是不支持的,例如下面的代码:
    <iframe src="
    http://www.google.com"></iframe>
    <script>
    setTimeout("document.frames[0].window.location.href",3000);
    </script>
    使用setTimeout是为了可以让iframe子页面可以加载完毕,上面的调用会报安全性警告,例如在ie如下:


    那么是不是说只要是跨域就能不能进行javascript访问了呢?不是的,一种比较常用的办法就是设置document.domain属性,这种方式的描述如下:
    假设有两个页面
    test1.html 所在域:aaa.maindomain.com 访问协议:http 端口:8080
    test2.html 所在域:bbb.maindomain.com 访问协议:http 端口:8080
    满 足上面条件的两个页面test1.html、test2.html是可以通过javascript相互访问的,上面的条件即为两个页面位于同一个基础域 (例如上面同为maindomain.com),遵循同一个访问协议和端口(例如上面同为http 8080)。只要在这样的两个页面中都设置document.domain为所在基础域名,就可以相互调用了,例如:
    test1.html 所在域为aaa.mydomain.com
    <script>
    document.domain="mydomain.com";
    </script>
    <iframe src=http://bbb.mydomain.com/test2.html></iframe>
    <script>
    setTimeout("document.frames[0].window.location.href",3000);
    </script>
    test2.html 所在域为bbb.mydomain.com
    <script>
    document.domain="mydomain.com";
    </script>
    ...
    这样一来,test1.html的调用就是可以的了。一般来说跨域调用的场景发生在集团型企业项目或多机构的政务项目中,而对于这种类型的项目,它们的基础域基本上是相同的,只是三级域名不同,因此可以使用上面的方式来进行跨域调用。

    22,你 会页面中的javascript调试吗?也许你还不会使用ie或firefox提供的页面调试器或插件,那么没有关系,至少你懂得一种最基本的调试: alert调试,不要认为这是一种很土或很傻的方式,很多时候这种方式都很非常有用的,对于一段很长的javascrip代码,从头到尾加入几个 alert,那么立即就能定位错误的大概位置,当然使用调试器的断点也可以很快定位,只是说alert也是一种不错的方式。当然还是希望你能够掌握更为高 级的调试器的使用,毕竟调试器带给我的功能更强大。

    23,在Javascript中字符串的替换函数为replace(regexp, newSubStr),其中第一个参数是一个正则表达式,但是我们在实际使用中,往往习惯使用为一个字符串,这虽然不会报错,但是得到的结果往往是不正确的,例如下面的例子:
    var str=“ abbbbacc”;
    var rs=str.replace(“a”,”0”);
    (A)0bbbbacc (B)0bbbb0cc
    正确答案是A,当然A可能不是你想要的结果,你想要的结果是字符串中所有的“a”都被替换为“0”,可是上面的使用方式只能将第一个“a”替换为“0”,正确的使用方式,在第一个参数中输入一个正则表达式,如下所示:
    var str=“ abbbbacc”;
    var rs=str.replace(“/a/g”,”0”);//注意如果第一个参数为/a/,结果也是不正确的。
    (A)0bbbbacc (B)0bbbb0cc
    这样的话答案就是B了,如果你不明白/a/g是什么意思,那么你就需要对Javascript的正则表达式好好学习了,具体可以参看我以前写过的一篇文章:
    http://blog.csdn.net/eye_of_back/archive/2006/07/14/922667.aspx

    24,网 页打印我们都知道可以调用window.print函数,那么如果想打印iframe子窗口中页面呢,如果你只是获得子窗口对象,然后调用子窗口对象的 print方法,此时打印机打印出却不是子窗口页面的内容,而是父窗口页面自身,为什么会这样呢?原来(至少在ie中如此)在父页面调用子窗口的 print函数时,因为此时焦点还在父窗口之中,所以打印机此时会将获得焦点的窗口进行打印,我们在打印子窗口之前,只需做一件事即可完成对子窗口的打 印,如下代码:
    <html>
    <head>
    <script>
        function myprint(){
           document.frames("myframe").window.focus();
           document.frames("myframe").window.print();
        }
    </script>
    </head>
    <body onload="myprint()">
    <iframe name="myframe" src="test2.html"></iframe>
    </body>
    </html>

    25,有些时候我们在<a/>标签的href中直接加入javascript代码,通过window.open来打开一个自己可以控制许多属性的窗口,例如下面的代码:
    <a href="javascript:window.open('http://www.google.com');">打开Google</a>
    当我们点击链接后,确实弹出了Google的页面,但同时原页面却变为了下面的样子:

    这种情况相信有些人遇到过,解决方式如下:
    <a href="javascript:window.open('http://www.google.com');window.opener=null;window.close()">打开Google</a>
    但是为什么前面的那种方式就会出现那种情况呢,其实只要做个简单实验就会明白了,你运行一下下面的代码,点击链接看看会出现什么结果:
    <a href="javascript:window">打开Google</a>
    实验后你会发现,点击链接后页面出现的结果与上面那种结果相同,然后你再实验一下下面的代码:
    <a href="javascript:'test'">打开Google</a>
    点击链接后,你会发现页面中会显示test字样。可见对于类似
    <a href="javascript:js代码">点击</a>
    的 代码,如果js代码执行完毕后返回一个对象,那么页面内容会被冲掉,然后将该对象的描述输出到页面中,我们知道window.open方法返回的是弹出的 页面的窗口对象(window),因此javascript:window.open将会在弹出一个窗口的同时,原页面会冲掉原有内容并将返回的 window对象输出到原页面中。如果在window.open后面加入window.opener=null;window.close(),则弹出窗 口后,返回给原页面的对象为空,则原页面不执行任何其它操作。

    26,在javascript中有一个方法可以列出当前对象所支持的所有属性、集合和事件,通过使用in关键字来实现,如下样例代码:
    var str="";
    for(var i in document){
        str+=i+"\n";
    }
    alert("document's all attributes:"+str);

    27,在 一个名称为myform的表单中,含有一个名称为mychckbox的复选框,那么document.myform.mycheckbox所取到的是那个 复选框对象,那么此时调用document.myform.mycheckbox.length是错误的,如果该表单中含有多个名称为 mycheckbox的复选框,那么document.myform.mycheckbox返回的是一个数组,此时调用 document.myform.mycheckbox.length就是正确的。单独说这个问题,可能感觉比较简单,但是在实际应用中我们经常会犯与此 相关的错误,如下图所示:

    上 图是我们在应用中经常遇到的“增、删、改”的逻辑,我们在其中经常会对复选框做操作,经常会使用类似 document.myform.mycheckbox.length的方式,一般情况不会报错,这主要是因为在我们的列表中一般来说都不会只有一条记 录,但是当列表中只有一条记录的时候(尽管这种时候不常见),这样引用就会报错,因为此时document.myform.mycheckbox返回的不 是一个数组,则对length的引用就没有意义了,这种错误说起来很容易,但是在编程时往往就会忽略,因此在编程时我们建议如下方式:
    if(document.myform.mycheckbox.length){
    //...
    }else{
    //...
    }

    28,在ie中有一个很特别的css语法,如果你听说过,那说明你的积累真是太丰富了!在css中有一种给汉语注音的语法,如下所示:
    <style>
        ruby{font-size:13pt;}
        rt{font-size:18pt;color:red}
    </style>
    <ruby>你知道这个语法吗?<rt>ni zhi dao zhe ge yu fa ma</rt><br>
    不知道<rt>bu zhi dao</rt>   
    </ruby>
    你运行这段代码看看什么效果(要在ie中运行),我这里效果如下:

    29,我 们项目中经常会遇到页面打印的需求,许多时候用户需要只打印页面某一部分,如果直接调用window.print则打印的是整个网页的内容。解决办法不外 乎两种,第一种方式是将整个页面分为几个部分,将需要打印的部分放在其中的一个部分,然后定义onbeforeprint和onafterprint两个 操作,即打印之前将不要打印的部分隐藏,打印之后将隐藏的部分显示,类似代码如下:
    <script>
       function beforePrint(){
           document.getElementById("hidden1").style.display="none";
           document.getElementById("hidden2").style.display="none";
       }
       function afterPrint(){
           document.getElementById("hidden1").style.display="block";
           document.getElementById("hidden2").style.display="block";
       }
       document.onbeforeprint=beforePrint;
       document.onafterprint=afterPrint;
    </script>
    <div id="hidden1" style="display:block">
    这里不需要打印
    </div>
    <div id="printDiv" style="display:block">
    这里需要打印
    </div>
    <div id="hidden2" style="display:block">
    这里不需要打印
    </div>
    <input type="button" value="打印" onclick="window.print()"/>
    第二种方式是将需要打印的部分放到iframe之中,然后将焦点移到子窗口,然后调用子窗口的print方法即可。

    30,Javascript 中的数组和我们一般的编程语言中的数组是不太一样,一般语言中数组的长度是固定的,有些语言中数组中的数据类型也要求是一样的,但是javascript 数组却不受这些限制,在javascript中数组基本上是没有长度限制的,而且类型也没有限制,例如下面的一些使用方法:
    var arr=new Array();
    arr[1000]="ok";
    arr[300]=255;
    arr[200]=new Date();
    var date=arr[200];
    alert(date.getTime());
    因为数组的这种机制,我们可以使用数组实现许多数据结构,例如列表、哈西表等等。

  • 相关阅读:
    导入测试用例的设计
    质量管理的精髓
    ios crash的原因与抓取crash日志的方法
    怎样实现excel隔行隔列变色效果的方法
    如何提高员工的质量意识?
    史上最全的测试团队组建方法
    如何写好缺陷报告?
    你还不知道?这四个因素决定了你的养老金待遇!
    各手机截屏方法收集
    利用drozer进行Android渗透测试
  • 原文地址:https://www.cnblogs.com/liufei88866/p/1052653.html
Copyright © 2011-2022 走看看