- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在两件事上遇到了麻烦:
我尝试使用::ng-deep 覆盖 css 属性并将颜色更改为白色,尝试配置 invisibility:hidden 但没有成功。此外,我尝试使用 ngStyle 将 p 标签的背景颜色配置为蓝色(如果选中),但它不起作用。
这是 HTML:
<div class="container-fluid">
<header class="lesson-heading" *ngIf="currentQuestion">
<span class="title"></span>
<h2>Question {{currentIndex + 1}}/{{quiz.questions.length}}</h2>
</header><!-- end lesson-heading -->
<div class="question-block">
<form #quizForm="ngForm" (ngSubmit)="onSubmit()">
<h4>{{currentQuestion.question}}</h4>
<div class="form-group">
<mat-radio-group [(ngModel)]="userAnswers[currentIndex]" name="answer" class="form-control">
<ul class="items answers-list">
<li><mat-radio-button [value]=1><p>1. {{currentQuestion.answer1}}</p></mat-radio-button></li>
<li><mat-radio-button [value]=2><p>2. {{currentQuestion.answer2}}</p></mat-radio-button></li>
<li><mat-radio-button [value]=3><p>3. {{currentQuestion.answer3}}</p></mat-radio-button></li>
<li><mat-radio-button [value]=4><p>4. {{currentQuestion.answer4}}</p></mat-radio-button></li>
</ul>
</mat-radio-group>
</div>
</form>
</div>
</div>
和 SASS 文件:
/*click effect color change*/
::ng-deep .mat-radio-button.mat-accent .mat-radio-ripple .mat-ripple-element
background-color: white !important
visibility: hidden !important
/*inner circle color change*/
::ng-deep .mat-radio-button.mat-accent .mat-radio-inner-circle
background-color: white !important
visibility: hidden !important
/*outer ring color change*/
::ng-deep.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle
background-color: white !important
visibility: hidden !important
最佳答案
你的样式有一些问题:
visibility: hidden
将隐藏元素的内容,但不会“释放”元素阻挡的空间
.mat-radio-outer-circle
的可见性仅在由于 .mat-radio-checked
disableRipple="true"
1)如何隐藏mat-radio-group的圆圈并禁用波纹?
我已经将样式调整如下:
::ng-deep .mat-radio-button .mat-radio-container {
width: 0;
}
::ng-deep .mat-radio-container .mat-radio-outer-circle,
::ng-deep .mat-radio-container .mat-radio-inner-circle {
border: none;
width: 0;
}
并将 disableRipple="true"
添加到 mat-radio-button
<mat-radio-button disableRipple="true" [value]="answer.value">
2) 如果勾选了一个选项,如何改变背景?
对于选中的选项的背景颜色,我已将 ngStyle 属性指令添加到 li 元素,并将所选选项的索引与存储在当前问题的 userAnswers 中的值进行比较:
<li [ngStyle]="{'background-color':userAnswers[currentIndex] === i+1?'blue':'transparent'}"> ... </li>
为了让它工作,我不得不稍微修改一下 html(如果你在循环中创建你的选项,你可以节省几行代码,并且很容易一次禁用所有选项的涟漪) :
<li class="answer"
[ngStyle]="{'background-color':userAnswers[currentIndex] === i+1?'blue':'transparent'}"
*ngFor="let answer of currentQuestion.answers; let i = index">
<mat-radio-button disableRipple="true" [value]="answer.value">
<p>{{ i+1 }}. {{ answer.text }}</p>
</mat-radio-button>
</li>
或者,您也可以使用 ngClass
而不是 ngStyle
。只需添加
[ngClass]="{'active': userAnswers[currentIndex] === i+1}"
到 li 元素而不是 ngStyle 指令并添加以下样式定义
.answer.active {
background: lightblue;
}
预览
看看这个 Stackblitz它使用两种变体(ngClass 和 ngStyle)
关于 Angular 6 : How to hide radio circle using Angular Material and use NgStyle for checked answer?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53944686/
这个问题在这里已经有了答案: What's the proper value for a checked attribute of an HTML checkbox? (10 个答案) 关闭 8 年
我使用这个制作了自定义复选框: enter link description here 也可在 stackoverflow 上获得:enter link description here 但我正在尝试
我需要使用 CSS“checkbox-hack”来实现滑动菜单指示器效果,我唯一的方法是通过 JavaScript 附加输入元素。我被迫通过在线工具 MonoSolutions 执行此操作,并且我受到
此代码运行良好,但缺少一些我需要的东西。基本上,如果输入有一个 checked="checked" 属性,它应该使其他两个元素保持禁用状态。如果未选中,则元素已启用。 这是我在 jsFiddle 上的
当我的人 checkout 文件时,我希望他们将其锁定,以便其他人也无法进行更改,我从这篇文章中看到:http://msdn.microsoft.com/en-us/library/jj155783.
请告诉我这些函数的作用。 最佳答案 这些是基于框架的、与语言无关的方法,用于在 .NET 中定义代码契约。虽然某些语言(如 spec# 和 Delphi Prism)对代码契约具有一流的语言支持,但这
假设以下场景:您有 2 个单选按钮,它们具有相同的名称,并且都被选中(我知道这是无效的): 为什么下面两个选择器的行为不同? $('.input:checked').size(); // retu
我正在尝试收听广播。以下均不起作用: [编辑] $('selector').attr('checked','checked'); $('selector').attr('checked',true);
我实际上在努力理解此类型错误。 任何人都知道我如何更正代码?谢谢 CheckIn checkin1 = new CheckIn(location1, dt); CheckInMonths checkI
我有这段代码,但不起作用。 .on("click","span.name", function selectThisName(e) { if (e.altKey) {
我现在是 Espresso 的新手,我遇到了这个异常: android.support.test.espresso.AmbiguousViewMatcherException: 'with id: a
我已经创建了一个基本的 2 单选按钮表单,如下面的示例所示。 观察浏览器渲染,我们看到元素 1 被选中。我们检查元素 1 和元素 2。 当我点击元素 2 时,我希望元素 1 的 checked=che
我在查找以下 jquery/checkbox 行为的原因时遇到问题。 $( this.obj + ' table.sgrid-content > thead > tr > th > input.sel
以下逻辑应用在上午 10 点触发并运行 SQL Server 查询。从图片中可以看出,结果集是空的。 条件检查检查查询的结果集是否为空。 (第二张图) 这仍然如何转化为 True?结果显然是空的。 最
我想知道哪种操作更快: int c = version1.compareTo(version2); 这个 if (c == 1) 或者这个 if (c > 0) 符号比较是否只使用一位检查,而相等比较
我有一个包含大约 100 个问题的表单,每个问题都有一个单选按钮和一些复选框,因此我需要用户能够保存表单并在以后加载它。我还需要检查用户在此 session 中更改了哪些。 本题解决问题:How ca
我正在编写一个小程序,需要用户决定一些 bool 值。我已经制作了复选框来处理这一部分,但问题是每次我选中或取消选中一个复选框时,所有其他复选框都会跟随。 我在网上搜索过,但我找到的唯一解释( pyt
我有以下代码片段(我使用的是 jQuery 1.4.2): $.post('/Ads/GetAdStatsRow/', { 'ad_id': id }, function(result) {
我的代码发生了一些奇怪的事情。我有两个按钮,其中一个带有 .add 和 .remove 类,有一个复选框会根据按下哪个按钮而打开和关闭,因此如果您使用删除按钮删除,则选中的复选框将被选中,否则复选框将
我陷入了一种情况,我必须通过“选中”工具栏中的复选框来“选中”列表中存在的所有复选框。 这是创建复选框列表的代码:- itemTpl: 'checked="checked" /> {groupName
我是一名优秀的程序员,十分优秀!