修改uniapp中 input 的 placeholder 样式

使用placeholder-class增加类名(这个可以

html 复制代码
<input type="text" class="search-input" placeholder-class="search-input-placeholder" placeholder="输入关键词搜索" />

<style scoped>
/deep/ .search-input-placeholder {
	color: red;
}
</style>

但是有限制和注意点

  1. 只能使用font-size、font-weight、color这几个属性
  2. 如果style中有scoped时,需要在类名前加上/deep/

使用placeholder-style直接写行内样式(这个我没生效

html 复制代码
<input type="text" class="search-input" placeholder-style="color: red" placeholder="输入关键词搜索" />

使用原生css方法修改(这个我没生效

css 复制代码
input::placeholder {
  // some code
}
<!-- 其他浏览器兼容 -->
/* - Chrome ≤56,
- Safari 5-10.0
- iOS Safari 4.2-10.2
- Opera 15-43
- Opera Mobile >12
- Android Browser 2.1-4.4.4
- Samsung Internet
- UC Browser for Android
- QQ Browser */
::-webkit-input-placeholder {
  color: #ccc;
  font-weight: 400;
}

/* Firefox 4-18 */
:-moz-placeholder {
  color: #ccc;
  font-weight: 400;
}

/* Firefox 19-50 */
::-moz-placeholder {
  color: #ccc;
  font-weight: 400;
}

/* - Internet Explorer 10--11
- Internet Explorer Mobile 10-11 */
:-ms-input-placeholder {
  color: #ccc !important;
  font-weight: 400 !important;
}

/* Edge (also supports ::-webkit-input-placeholder) */
::-ms-input-placeholder {
  color: #ccc;
  font-weight: 400;
}

/* CSS Working Draft */
::placeholder {
  color: #ccc;
  font-weight: 400;
}

有些样式是生效到input元素的属性中的

比如我这边本次就是要修改padding-left,最后暂时放弃先去修改输入值的属性的时候无意中发现的

css 复制代码
.search-input {
	background-color: #fff;
	height: 70rpx;
	width: 460rpx;
	border-radius: 250rpx;
	padding-left: 64rpx;
}
相关推荐
恶猫1 分钟前
javascript文本长度检测与自动截取,用于标题长度检测
javascript·css·css3·js·自动检测·文本长度
Hilaku1 小时前
我为什么认为 CSS-in-JS 是一个失败的技术?
前端·css·前端框架
Giant1002 小时前
0 基础也能懂的 Flex 布局教程:3 步搞定网页排版
css
Sherry0072 小时前
【译】掌握 Flexbox 的终极指南:从烤肉串到鸡尾酒香肠的布局哲学
css·面试·flexbox
!win !3 小时前
uni-app项目支付宝端Input不受控
小程序·uni-app·支付宝小程序
xw53 小时前
uni-app项目支付宝端Input不受控
前端·uni-app·支付宝
那一抹阳光多灿烂5 小时前
CSS 编码规范
前端·css
degree5205 小时前
CSS :has() 选择器详解:为什么它是“父选择器”?如何实现真正的容器查询?
前端·css·css3
૮・ﻌ・5 小时前
CSS高级技巧---精灵图、字体图标、布局技巧
前端·css
昔人'5 小时前
纯`css`固定标题并在滚动时为其添加动画
前端·css