Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 656|回复: 0

前端页面显示问题解决步骤(方法)

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-8-30 13:16:53 | 显示全部楼层 |阅读模式

    一 :背景

    1.1 测试提出的bug,我查看了一下其他页面选择时间的控件。通过对比发现别人用的glyphicon-arrow-left 尔我用的是 icon-arrow-left  而且百度也没有找到相关问题的解决办法。

    1.2 对于这种查阅百度也找不到解决的办法,也只能试试运气查看源码(bootstrap-datetimepicker.js)了。

    1.3 通过(CTRL + F)在bootstrap-datetimepicker.js查找关键字 icon-arrow-left  我发现以下代码 

     this.icons = {
          leftArrow: this.fontAwesome ? 'fa-arrow-left' : (this.bootcssVer === 3 ? 'glyphicon-arrow-left' : 'icon-arrow-left'),
          rightArrow: this.fontAwesome ? 'fa-arrow-right' : (this.bootcssVer === 3 ? 'glyphicon-arrow-right' : 'icon-arrow-right')
        }

    解读代码::我们发现左右箭头图 就是this.icons对象(this是Datetimepicker类的一个实例)的两个属性值 leftArrow(左箭头)rightArrow(右箭头),而这个值和this.bootcssVer的属性有关。

    1.4 然后我们继续查找bootcssVer 关键字>在87行我们查找到如下代码

    this.bootcssVer = options.bootcssVer || (this.isInput ? (this.element.is('.form-control') ? 3 : 2) : ( this.bootcssVer = this.element.is('.input-group') ? 3 : 2 ));

    解读代码: 我们发现,this.bootcssVer 的值和当前是否是input(this.isInput)标签和该标签的class(this.element.is('.form-control'))属性的值有关。现在问题已经很明显了,我的input属性没有class = "form-control"

    备注:三目运算:: var s  =  expr  ?  "v1 " : "v2 "      如果expr为true  则 s =  v1  否则相反

       双目运算:: var s  =  expr1 || expr2   如果expr1不为false  则 s =  expr1  否则相反  例如1   var  s = false || 2   >> s = 2   。例如2  var  s = 3 || 2   >> s = 3  。  

     1.5 通过在源码87行(改行赋值bootcssVer的值)打一个断点,不出所料该值为2,我的input属性缺少class = "form-control"。

    二:源发分析(主要从结构上分解官方如何定义一个js类的过程)

    2.1  最外层,一个立即执行函数,并把jquery对象传入该方法中,结构如下

    !function ($) {
      /**
      * 在该函数内部定义js对象(Datetimepicker),和其他一些赋值方法和常量
      */
    }(window.jQuery);

    技巧: 立即执行函数传入window.jQuery对象,并用‘$’接受,该函数内部可通过$来代表window.jQuery对象了,就像我么平时使用window.jQuery对象一样用$.

    2.2 该源码(bootstrap-datetimepicker.js)的第一段代码 

    if (!('indexOf' in Array.prototype)) {   //遍历Array.prototype原型的所有属性,判断是否有indexof方法
        Array.prototype.indexOf = function (find, i) { //定义Array对象得indexOf方法
          if (i === undefined) i = 0;
          if (i < 0) i += this.length;
          if (i < 0) i = 0;
          for (var n = this.length; i < n; i++) {
            if (i in this && this === find) {
              return i;
            }
          }
          return -1;
        }
      }

    解读:该段代码是兼容js代码的版本。可借鉴写法(( ))

    2.3   定义Datetimepicker类的构造器(函数表达式)

    var Datetimepicker = function (element, options) {
        var that = this; //如果是通过关键字new创建对象,this就代表该对象,如果是调用普通方法该this就是window.
       this.bootcssVer =  //这个属性就是
    : :
       这里面全部是定义属性,没有定义方法。
       方法的定义全部在原型上定义
    }

    备注;他定义属性的方式都是this.属性名 ,而不是通过var 声明的

    2.4 定义Datetimepicker类原型方法

    Datetimepicker.prototype = {
        constructor: Datetimepicker, // 让当前对象构造器指向自己,要然就会指向Object对象的原型
    
        _events:       [], //私有方法
        _attachEvents: function () {},
    
        _detachEvents: function () {},
    
        show: function (e) {}, //公共方法
    
        hide: function (e) {},
    }

    2.5 让该对象成为jQuery的扩张属性(定义jQuery插件)

    $.fn.datetimepicker = function (option) {
        var args = Array.apply(null, arguments);
        args.shift();
        var internal_return;
        this.each(function () {
          var $this = $(this),
            data = $this.data('datetimepicker'),
            options = typeof option == 'object' && option;
          if (!data) {
            $this.data('datetimepicker', (data = new Datetimepicker(this, $.extend({}, $.fn.datetimepicker.defaults, options)))); //创建Datetimepicker实例,返回给jQuery对象得datetimepicker
    属性值。 }
    if (typeof option == 'string' && typeof data[option] == 'function') { internal_return = data[option].apply(data, args); if (internal_return !== undefined) { return false; } } }); if (internal_return !== undefined) return internal_return; else return this; };

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-4-25 14:15 , Processed in 0.074516 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表