从bootstrap应用css类时的PrimeNG日历错误

Shi*_*rod 8 css twitter-bootstrap primeng angular primeng-calendar

我有这个奇怪的错误,我使用PrimeNG在我的应用程序中显示DatePicker.当我尝试使用bootstrap时form-control,我得到了一个视觉错误.

这是我的模板:

<div class="form-group row">
    <div class="form-group col-md-2">
        <label for="valeur">Valeur</label>
        <input type="number" id="valeur" class="form-control" />
    </div>

    <div class="form-group col-md-5">
        <label for="dateDebut">Date de début</label>
        <p-calendar id="dateDebut" dateFormat="dd/mm/yy" styleClass="form-control" [showIcon]="true"></p-calendar>
    </div>

    <div class="form-group col-md-5">
        <label for="dateFin">Date de fin</label>
        <p-calendar id="dateFin" dateFormat="dd/mm/yy" styleClass="form-control" [showIcon]="true"></p-calendar>
    </div>
</div>
Run Code Online (Sandbox Code Playgroud)

这是结果:

在此输入图像描述

编辑

如果它有任何帮助,这里是生成的HTML:

<div class="form-group col-md-5" _ngcontent-scp-1="">
   <label for="dateDebut" _ngcontent-scp-1="">Date de début</label>
   <p-calendar ng-reflect-show-icon="true" ng-reflect-date-format="dd/mm/yy" ng-reflect-style-class="form-control" styleclass="form-control" id="dateDebut" dateformat="dd/mm/yy" _ngcontent-scp-1="">
      <!--template bindings={
         "ng-reflect-ng-if": "true"
         }-->
      <span ng-reflect-initial-classes="form-control" class="form-control ui-calendar" ng-reflect-raw-class="ui-calendar">
         <input id="dp1467976345328" ng-reflect-value="" class="hasDatepicker ui-inputtext ui-widget ui-state-default ui-corner-left" ng-reflect-raw-class="[object Object]" type="text"><!--template bindings={
            "ng-reflect-ng-if": "true"
            }--><button ng-reflect-icon="fa-calendar" type="button" pbutton="" class="ui-datepicker-trigger ui-button ui-widget ui-state-default ui-corner-all ui-button-icon-only"><span class="ui-button-icon-left ui-c fa fa-fw fa-calendar"></span><span class="ui-button-text ui-c">ui-button</span></button>
      </span>
      <!--template bindings={
         "ng-reflect-ng-if": "false"
         }-->
   </p-calendar>
</div>
Run Code Online (Sandbox Code Playgroud)

iPa*_*aul 6

我使用了以下解决方法,这在IE和Chrome中都运行良好:

<p-calendar [inputStyle]="{'width':'55%'}" ...
Run Code Online (Sandbox Code Playgroud)

试试吧


Ste*_*ota 5

PrimeNG的日历组件有四个造型属性,二为增加内联样式和两个用于添加样式(css)班- ,,style 和。styleClassinputStyleinputStyleClass

  • stylestyleClass用于设置组件本身的样式(日历)
  • inputStyleinputStyleClass用于设置输入字段的样式

因此,此行为不是bug,而是预期的行为,因为您使用的是错误的属性。如果您想将form-control类添加到PrimeNG的日历输入字段中,则应使用inputStyleClass而不是styleClass属性:

 <div class="form-group col-md-5">
    <label for="dateFin">Date de fin</label>
    <p-calendar id="dateFin" dateFormat="dd/mm/yy" inputStyleClass="form-control" [showIcon]="true"></p-calendar>
</div>
Run Code Online (Sandbox Code Playgroud)

在此处检查PrimeNG日历组件的整个属性列表。