【css】Google第三方登录按钮样式修改

文章目录

场景

需要用到谷歌的第三方登录,登录按钮有自己的样式。根据官方文档:概览 | Authentication | Google for Developers,提供两种第三方登录的API:HTML版和JS版。它们都使用的是封装好的按钮。也就是说,目前不能自己放置一个图片,点击它跳转第三方登录,而是只能在原有官方按钮的基础上对它的样式进行修改

ps:访问谷歌文档需要科学上网。

前置准备

根据文档,引入客户端库:

如果不想总是访问谷歌的库,可以进入此链接,把对应的代码复制到本地,本地引入库或上传到CDN引入

html 复制代码
<script src="https://accounts.google.com/gsi/client" async></script>

根据文档的生成 HTML 代码 | Authentication | Google for Developers自动生成谷歌第三方登录的代码(这里的data-client_id随便在sandbox上搜的):

html 复制代码
<div id="g_id_onload"
     data-client_id="414565162824-iolb7mcqbt5j4v86evnnenajdim87vhc.apps.googleusercontent.com"
     data-context="signin"
     data-ux_mode="popup"
     data-login_uri="http://localhost:3003"
     data-auto_prompt="false">
</div>

<div class="g_id_signin"
     data-type="standard"
     data-shape="rectangular"
     data-theme="outline"
     data-text="signin_with"
     data-size="large"
     data-logo_alignment="left">
</div>

看看效果:

修改样式

是很好的CSS选择器优先级练习

假设我们的目标是这样:

那么我们需要修改它的宽高、border-radius、logo和文字的位置或布局等。

官方属性修改样式

"使用 Google 帐号登录"HTML API 参考文档 | Authentication | Google for Developers

googleBtn是自己加的类,用来改css。

html 复制代码
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<title>Document</title>
	</head>

	<style></style>
	<body>
		<script
			src="https://accounts.google.com/gsi/client?hl=en"
			async
		></script>

		<div
			id="g_id_onload"
			data-client_id="414565162824-iolb7mcqbt5j4v86evnnenajdim87vhc.apps.googleusercontent.com"
			data-context="signin"
			data-ux_mode="popup"
			data-login_uri="http://localhost:3003"
			data-auto_prompt="false"
		></div>

		<div
			class="g_id_signin googleBtn"
			data-type="standard"
			data-shape="pill"
			data-theme="outline"
			data-text="signin_with"
			data-size="large"
			data-logo_alignment="left"
			data-locale="en_GB"
		></div>
	</body>
</html>

CSS修改样式

接下来是CSS修改样式。

按钮代码如下:

按钮的高度height和border-radius

对应位置:

css 复制代码
.googleBtn > div > div > div[role="button"] {
	height: 48px;
	border-radius: 99px;
}

注意要加属性选择器,不然可能选择器优先级不够。

Logo和文字布局

logo:

css 复制代码
.googleBtn > div > div > div[role="button"] > div > div{
	/*可以修改logo的width、height、margin等*/
}

文字:

这里是第一个span:

css 复制代码
.googleBtn > div > div > div[role="button"] > div:nth-child(2) > span {

}

它们的布局:

这里是flex布局,设置了justify-content: space-between;。如果想改:

css 复制代码
.googleBtn > div > div > div[role="button"] > div:nth-child(2) {
	
}
相关推荐
老王以为15 分钟前
Claude Code 的产品哲学:当价值观成为架构
前端·claude·vibecoding
程序员黑豆18 分钟前
AI全栈开发 - Java:变量
java·前端·ai编程
tedcloud12322 分钟前
HyperFrames部署教程:用HTML生成MP4视频
前端·数据库·人工智能·html·音视频
江米小枣tonylua28 分钟前
真多线程!Bun作者要给JS大手术
前端
YIAN1 小时前
# 从入门到封装:一文搞懂 Fetch API 所有用法(新手友好)
前端·javascript
Slice_cy1 小时前
基于node实现服务端内核引擎
前端·后端
往事随风灬1 小时前
我被 Volta 的“智能”坑了一下午:pnpm 为何无视项目 Node 版本?
前端·vue.js
xiaofeichaichai1 小时前
Tree Shaking
前端·javascript
lichenyang4531 小时前
给 ArkTS 应用做一个内置的「Network 面板」:实时看清 SSE 每一帧和最后那张卡片
前端
倾颜1 小时前
从手写 Runner 到 LangGraph:受控 Agent 接入 LangGraph
前端·后端·langchain