body { display:flex; align-items:center; height:100vh; justify-content:center; font-size:14px; color:#555; padding:0px 20px; overflow-y:auto; margin:0; } .icon-collect { margin:20px; } .icon-collect { min-width:3em; height:3em; border-radius:3em; cursor:pointer; position:relative; transition:background-color 0.3s; background-color:#ea4c4c; background-repeat:no-repeat; background-size:2em; background-position:center center; background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACoAAAAqCAYAAADFw8lbAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKFdpbmRvd3MpIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjgwQjgwQkNCMzEyMTExRUE5MEEwOTdGMTc2ODM4RDQ3IiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjgwQjgwQkNDMzEyMTExRUE5MEEwOTdGMTc2ODM4RDQ3Ij4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6ODBCODBCQzkzMTIxMTFFQTkwQTA5N0YxNzY4MzhENDciIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6ODBCODBCQ0EzMTIxMTFFQTkwQTA5N0YxNzY4MzhENDciLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz4VLE1SAAABgklEQVR42uyYsUoDQRCGs5qoKYJNsBJTqJAXsDVgYxHSpbDRwhfwMdRGU4lVwEoEMdgJMSEhRdA8QTC9YiyEYJvNv7AHKeI5ezcLBmbggyuGm4/budllldY6MQ+xkJiTEFERFVERFVERnRkKHIAWGIEf0AFHIe8qgnswAH37vO9savZ6IkvgTv8edbA6lZ8BDyH5VZCk1ncRvdB/xzNYtNQJ+ZfU+op4etqyy0ZplRPbIhVC7hjkwRvX0p9regzBp0N+heKQJLbynkPbZx1/kwLnX5/zOHk2SeOG2KNj23e+QnF90aFHyXfOpW95FO1wil6ZAeFBUhPHGFm0Da49iJ6BLvcWanabG80Xpw61nUQDjsEohqDZEMqudaOIGrZBM4LkLViLUjOqqMHM4EPwRRD8AKUYtWKJBmyA1xDJHliPW4dD1LAMajMkn0CaowaXaHCwfpySbIAVrvcr5tu8DHgBKbADvtkOAx6uHXftIaPNemqR+1ERFVERFVER/VcxEWAA3pyX09PuzJEAAAAASUVORK5CYII=); } .icon-collect::before,.icon-collect::after { content:""; position:absolute; border-radius:100%; pointer-events:none; display:block; } .icon-collect::before { width:3em; height:3em; top:-1px; left:-1px; border:1px solid #ea4c4c; opacity:0; } .icon-collect::after { width:8px; height:8px; position:absolute; padding:0 !important; display:inline-block; opacity:0; border-radius:100%; box-shadow:calc(1.5em) calc(-1.5em + 8px) 0px 0px #e94c4c,0px calc(-1.5em - 4px) 0px 0px #4CAF50,calc(-1.5em) calc(-1.5em + 8px) 0px 0px #009688,0px calc(1.5em + 4px) 0px 0px #673AB7,calc(1.5em) calc(1.5em - 8px) 0px 0px #FF9800,calc(-1.5em) calc(1.5em - 8px) 0px 0px #795548; pointer-events:none; left:calc(50% - 4px); top:calc(50% - 4px); } .icon-collect.collected { /* fill white heart */ background-image:url(data:image/png; base64,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); animation:collect-image-scale 0.5s linear; } .icon-collect.collected.animation::before { animation:collect-before 1s cubic-bezier(0.03,0.16,0.4,1.68); } .icon-collect.collected.animation::after { animation:collect-after 1s cubic-bezier(0.48,0.37,0.43,0.42) forwards; } /* star */ .icon-collect.star-icon { background-color:#FF9800; /* background-image:*/ } .icon-collect.star-icon.collected { /* background-image:*/ } .icon-collect.star-icon::before { border-color:#FF9800; } /* star */ /* outline border */ .icon-collect.border-icon { border:1px solid #ea4c4c; } .icon-collect.star-icon.border-icon { border:1px solid #FF9800; } /* outline border */ @keyframes collect-image-scale { 0% { background-size:0px; } 40% { background-size:2.4em; } 60% { background-size:1.6em; } 70% { background-size:2.2em; } 80% { background-size:1.9em; } 90% { background-size:2.1em; } 100% { background-size:2em; } }@keyframes collect-before { 0%,70% { border-width:1px; } 0% { opacity:1; transform:scale(1); } 100% { transform:scale(2.5); border-width:0px; opacity:0; } }@keyframes collect-after { 0% { opacity:0; transform:scale(1); box-shadow:calc(1.5em) calc(-1.5em + 8px) 0px 0px #e94c4c,0px calc(-1.5em - 4px) 0px 0px #4CAF50,calc(-1.5em) calc(-1.5em + 8px) 0px 0px #009688,0px calc(1.5em + 4px) 0px 0px #673AB7,calc(1.5em) calc(1.5em - 8px) 0px 0px #FF9800,calc(-1.5em) calc(1.5em - 8px) 0px 0px #795548; } 20% { opacity:1; } 100% { opacity:0; transform:scale(5); box-shadow:calc(1.5em) calc(-1.5em + 8px) 0px -10px #e94c4c,0px calc(-1.5em - 4px) 0px -10px #4CAF50,calc(-1.5em) calc(-1.5em + 8px) 0px -10px #009688,0px calc(1.5em + 4px) 0px -10px #673AB7,calc(1.5em) calc(1.5em - 8px) 0px -10px #FF9800,calc(-1.5em) calc(1.5em - 8px) 0px -10px #795548; } }@keyframes collect-after-2 { 0% { opacity:0; transform:scale(1); box-shadow:20px -10px 0px 0px #e94c4c,0px -22px 0px 0px #4CAF50,-20px -10px 0px 0px #009688,0px 22px 0px 0px #673AB7,20px 12px 0px 0px #FF9800,-20px 13px 0px 0px #795548; } 20% { opacity:1; } 100% { opacity:0; transform:scale(5); box-shadow:20px -10px 0px -10px #e94c4c,0px -22px 0px -10px #4CAF50,-20px -10px 0px -10px #009688,0px 22px 0px -10px #673AB7,20px 12px 0px -10px #FF9800,-20px 13px 0px -10px #795548; } }/* ie */ @media screen and (-ms-high-contrast:active),(-ms-high-contrast:none) { .icon-collect::after { box-shadow:20px -10px 0px 0px #e94c4c,0px -22px 0px 0px #4CAF50,-20px -10px 0px 0px #009688,0px 22px 0px 0px #673AB7,20px 12px 0px 0px #FF9800,-20px 13px 0px 0px #795548 !important; } .icon-collect.animation.collected::after { animation:collect-after-2 1s cubic-bezier(0.48,0.37,0.43,0.42) forwards !important; } }/* edge */ _:-ms-lang(x),_::-webkit-meter-bar,.icon-collect::after { box-shadow:20px -10px 0px 0px #e94c4c,0px -22px 0px 0px #4CAF50,-20px -10px 0px 0px #009688,0px 22px 0px 0px #673AB7,20px 12px 0px 0px #FF9800,-20px 13px 0px 0px #795548 !important; } _:-ms-lang(x),_::-webkit-meter-bar,.icon-collect.animation.collected::after { animation:collect-after-2 1s cubic-bezier(0.48,0.37,0.43,0.42) forwards !important; }
更新时间:2020-01-07 15:45:26
图片使用的base64编码所以比较css字数比较多,受限于代码字符数20000的限制,所以其他图标和底色的样式没法上传了,有需要的可以自行修改backgroud-image,background-color即可。