IE8下的Input输入框不能输入、全选,光标在框外,而且又粗又大是怎么一回事? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
请不要在回答技术问题时复制粘贴 AI 生成的内容
Niphor

IE8下的Input输入框不能输入、全选,光标在框外,而且又粗又大是怎么一回事?

  •  
  •   Niphor
    niphor Jul 13, 2013 6328 views
    This topic created in 4674 days ago, the information mentioned may be changed or developed.
    今天测试童鞋说代码里面输入框不能用了。
    我以为是js问题,看了一下,我和小朋友们都惊呆了...

    问题的出现很随机,我点了N久好不容易出现了
    代码的流程主要是ajax获取 编辑界面html,然后用个dialog插件显示html内容。
    对话框生成时 童鞋用了 xheditor和swfupload (其一或者两者)
    架子大体是 seajs jquery jqueryUI构成的...

    先给看2张图:

    这张图是当Bug产生时,用js代码删除所有页面元素,并动态插入一个“<input />”,赋值之后的样子

    当中那个 黑色矩形 我感觉是光标(下面我就简称它是 cursor了),因为它一闪一闪,而且不是页面元素,它一直在全屏时的页面底部,并不会因为浏览器窗口大小改变而变化位置,也就说你缩小浏览器高度就看不见它了...

    这是在Input上右键的菜单

    似乎“全选”可以选择,但是没有任何效果。


    默认时 cursor是不会出现的,我右键选了全选,然后左键试图拖拉选择文本框内的文字时,试了几次才出现的...

    因为是新插入的input,原则上是没有任何自定义事件的...

    而问题产生时 textarea也会无法输入,但是它能右键全选,并且全选一次后点击一下里面空白处,光标就出现了,并且整个页面的input和textarea都痊愈了...




    我觉得这更像是IE的Bug而不是Js导致的
    我Google了一番,没见到有用的信息

    有童鞋见过类似问题没?
    THX.
    10 replies    1970-01-01 08:00:00 +08:00
    Niphor
        1
    Niphor  
    OP
       Jul 15, 2013
    果然太奇葩了么...
    loethen
        2
    loethen  
       Jul 15, 2013
    粗大,霸气,围观。
    ijse
        3
    ijse  
       Jul 15, 2013
    试试在Chrome下?
    liveme
        4
    liveme  
       Jul 15, 2013
    哪里弄错了吧,改一下input字体的颜色,看那坨cursor会不会跟着改变颜色。
    Niphor
        5
    Niphor  
    OP
       Jul 16, 2013
    @ijse
    Chrome下应该没有,也就XP下的IE8这样 <8的不考虑了也就没测

    @liveme
    应该不会变,因为之前页面上也有些许样式,不过都无法对它产生影响...
    Hyperion
        6
    Hyperion  
       Jul 16, 2013
    不给实际代码很难想象啊... 而且描述的也不是很清楚...
    liveme
        7
    liveme  
       Jul 17, 2013
    @Niphor 如果赋样式后没有相应的效果的话,那应该就不会是光标了吧。没看到代码,调试不了。
    Niphor
        8
    Niphor  
    OP
       Jul 18, 2013
    @liveme
    我也想提供TestCase,不过没找到能确定重现的方法...
    (BTW 要是知道怎么样肯定重现,就能对应处理了...)

    来张出现问题时 改了Color之后的图:

    可以看到黑条下面所有的物体的颜色都是反色的。
    甚至如果开发工具的选择框(就是那选中时的绿框)在下面,也会反色成黄的,而且只有是黑条下面那部分这样。
    这里还有个奇怪的地方,如果你鼠标移到xheditor菜单栏上面,只要某个菜单有下拉菜单弹出,则input又会痊愈...

    @Hyperion
    抱歉了,可能我表达能力不好
    给个图你,当弹出的Dialog出现时,上面的文本框会出现主帖上的问题




    因为想到:
    当Dialog出现时,我会查找 Dialog里面的 input 并focus第一个input,因为没有对input的类型进行判断,如果第一个是hidden的,也会focus()

    做了下处理,查找text的input来focus,主帖里面的问题就基本不会出现了...

    于是,单独写了个 TestCase 用来动态向一个div插入 2个input(第一个hidden,第二个是text),然后focus第一个。

    不过我点到手酸都没能重现主帖的问题...OTL

    IE8下面input为hidden时focus有什么bug没?

    这个问题太奇葩了,我表示好蛋疼...
    Hyperion
        9
    Hyperion  
       Jul 18, 2013
    @Niphor 总觉得好像是在样式生效之前, 继承到了什么奇怪的属性造成错位了, 或者是插入的HTML标记有问题.

    有什么其他奇怪的IE Hack在使用吗? 有内存泄漏的问题存在嘛? 没办法直接调试, 只能尝试性的猜测一下了...
    Niphor
        10
    Niphor  
    OP
       Jul 20, 2013
    @Hyperion
    可以看主贴,那页面在Bug发生时,
    所有的link标签和style标签,div都被我干掉后,用jquery插入到body的一个单纯的input标签
    所以不会有什么样式继承的问题,也没什么IE Hack。
    并且可以证明 Bug是对页面上所有input生效的
    而且 这个Bug是随机出现的,你可能这次点了没有,下次就有了...痊愈后又不会再出现了...

    所以我认为和HTML代码 内存泄露 关系不是特别大
    另外自从我 focus时,指定选择 text并且不是disable的input之后,基本不会再现这个问题了

    所以我现在严重怀疑 这是focus +什么未知名的操作 导致的....

    真是抱歉没能提供TestCase,因为单独写没能重现
    外网上又没可直接提供的连接...
    About     Help     Advertise     Blog     API     FAQ     Solana     958 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 36ms UTC 18:47 PVG 02:47 LAX 11:47 JFK 14:47
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86