HTML preprocessors can make writing HTML more powerful or convenient. For instance, Markdown is designed to be easier to write and read for text documents and you could write a loop in Pug.
In CodePen, whatever you write in the HTML editor is what goes within the <body>
tags in a basic HTML5 template. So you don't have access to higher-up elements like the <html>
tag. If you want to add classes there that can affect the whole document, this is the place to do it.
In CodePen, whatever you write in the HTML editor is what goes within the <body>
tags in a basic HTML5 template. If you need things in the <head>
of the document, put that code here.
The resource you are linking to is using the 'http' protocol, which may not work when the browser is using https.
CSS preprocessors help make authoring CSS easier. All of them offer things like variables and mixins to provide convenient abstractions.
It's a common practice to apply CSS to a page that styles elements such that they are consistent across all browsers. We offer two of the most popular choices: normalize.css and a reset. Or, choose Neither and nothing will be applied.
To get the best cross-browser support, it is a common practice to apply vendor prefixes to CSS properties and values that require them to work. For instance -webkit-
or -moz-
.
We offer two popular choices: Autoprefixer (which processes your CSS server-side) and -prefix-free (which applies prefixes via a script, client-side).
Any URLs added here will be added as <link>
s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.
You can apply CSS to your Pen from any stylesheet on the web. Just put a URL to it here and we'll apply it, in the order you have them, before the CSS in the Pen itself.
You can also link to another Pen here (use the .css
URL Extension) and we'll pull the CSS from that Pen and include it. If it's using a matching preprocessor, use the appropriate URL Extension and we'll combine the code before preprocessing, so you can use the linked Pen as a true dependency.
JavaScript preprocessors can help make authoring JavaScript easier and more convenient.
Babel includes JSX processing.
Any URL's added here will be added as <script>
s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.
You can apply a script from anywhere on the web to your Pen. Just put a URL to it here and we'll add it, in the order you have them, before the JavaScript in the Pen itself.
If the script you link to has the file extension of a preprocessor, we'll attempt to process it before applying.
You can also link to another Pen here, and we'll pull the JavaScript from that Pen and include it. If it's using a matching preprocessor, we'll combine the code before preprocessing, so you can use the linked Pen as a true dependency.
Search for and use JavaScript packages from npm here. By selecting a package, an import
statement will be added to the top of the JavaScript editor for this package.
Using packages here is powered by esm.sh, which makes packages from npm not only available on a CDN, but prepares them for native JavaScript ESM usage.
All packages are different, so refer to their docs for how they work.
If you're using React / ReactDOM, make sure to turn on Babel for the JSX processing.
If active, Pens will autosave every 30 seconds after being saved once.
If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.
If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.
Visit your global Editor Settings.
.explain
div
h1 How to demo:
p
| Hold
strong CTRL
| and move the mouse around to outline the hovered DOM element.
p
| Hold
strong CTRL
| +
strong SHIFT
| to outline every element.
p
| Go into editor mode (Top-right ➡ "Change View" ➡ "Editor mode") and play with commented out custom configuration for Debucsser class.
p Debucsser make it easy to debug your CSS.
p
| You can apply custom class on hover, or grayscale all the page, everything you want... check it out 😎
button Got it
.wrapper
header.box.header
h1#title Debucsser
i#this-is-what-it-is “CSS debugging made easy”
.git
a.github-button(href='https://github.com/lucagez/Debucsser', data-icon='octicon-star', data-size='large', data-show-count='true', aria-label='Star lucagez/Debucsser on GitHub') Star
hr.bar
#main-article.box
.content
img.main-article-image(src='', alt='')
h1.title Duties of American Citizenship
i.subtitle
strong.author Theodore Roosevelt
| , January 26, 1883; Buffalo, New York
p.text
| Of course, in one sense, the first essential for a man’s being a good citizen is his possession
| of the home
| virtues of which we think when we call a man by the emphatic adjective of manly. No man can be a good citizen
| who is not a good husband and a good father, who is not honest in his dealings with other men and women,
| faithful to his friends and fearless in the presence of his foes, who has not got a sound heart, a sound
| mind, and a sound body; exactly as no amount of attention to civil duties will save a nation if the domestic
| life is undermined, or there is lack of the rude military virtues which alone can assure a country’s position
| in the world. In a free republic the ideal citizen must be one willing and able to take arms for the defense
| of the flag, exactly as the ideal citizen must be the father of many healthy children. A race must be strong
| and vigorous; it must be a race of good fighters and good breeders, else its wisdom will come to naught and
| its virtue be ineffective; and no sweetness and delicacy, no love for and appreciation of beauty in art or
| literature, no capacity for building up material prosperity can possibly atone for the lack of the great
| virile virtues. But this is aside from my subject, for what I wish to talk of is the attitude of the American
| citizen in civic life. It ought to be axiomatic in this country that every man must devote a reasonable share
| of his time to doing his duty in the Political life of the community. No man has a right to shirk his
| political duties under whatever plea of pleasure or business; and while such shirking may be pardoned in
| those of small cleans it is entirely unpardonable in those among whom it is most common–in the people whose
| circumstances give them freedom in the struggle for life. In so far as the community grows to think rightly,
| it will likewise grow to regard the young man of means who shirks his duty to the State in time of peace as
| being only one degree worse than the man who thus shirks it in time of war. A great many of our men in
| business, or of our young men who are bent on enjoying life (as they have a perfect right to do if only they
| do not sacrifice other things to enjoyment), rather plume themselves upon being good citizens if they even
| vote; yet voting is the very least of their duties, Nothing worth gaining is ever gained without effort. You
| can no more have freedom without striving and suffering for it than you can win success as a banker or a
| lawyer without labor and effort, without self-denial in youth and the display of a ready and alert
| intelligence in middle age. The people who say that they have not time to attend to politics are simply
| saying that they are unfit to live in a free community.
hr.bar
aside.box.sidebar
.content
img.Demostenes(src='https://upload.wikimedia.org/wikipedia/commons/thumb/4/48/D%C3%A9mosth%C3%A8ne_s%27exer%C3%A7ant_%C3%A0_la_parole_%281870%29_by_Jean-Jules-Antoine_Lecomte_du_Nou%C3%BF.jpg/220px-D%C3%A9mosth%C3%A8ne_s%27exer%C3%A7ant_%C3%A0_la_parole_%281870%29_by_Jean-Jules-Antoine_Lecomte_du_Nou%C3%BF.jpg', alt='')
h1.title The Third Philippic
i.subtitle
strong.author Demosthenes
| , 342 B.C., Athens, Greece
p.text
| It is this fate, I solemnly assure you, that I dread for you, when the time comes that you make
| your
| reckoning, and realize that there is no longer anything that can be done. May you never find yourselves, men
| of Athens, in such a position! Yet in any case, it were better to die ten thousand deaths, than to do
| anything out of servility towards Philip [or to sacrifice any of those who speak for your good]. A noble
| recompense did the people in Oreus receive, for entrusting themselves to Philip’s friends, and thrusting
| Euphraeus aside! And a noble recompense the democracy of Eretria, for driving away your envoys, and
| surrendering to Cleitarchus! They are slaves, scourged and butchered! A noble clemency did he show to the
| Olynthians, who elected Lasthenes to command the cavalry, and banished Apollonides! It is folly, and it is
| cowardice, to cherish hopes like these, to give way to evil counsels, to refuse to do anything that you
| should do, to listen to the advocates of the enemy’s cause, and to fancy that you dwell in so great a city
| that, whatever happens, you will not suffer any harm.
hr.bar
.content
img.The-luckiest-man(src='https://upload.wikimedia.org/wikipedia/commons/thumb/3/38/Lou_Gehrig_as_a_new_Yankee_11_Jun_1923.jpg/235px-Lou_Gehrig_as_a_new_Yankee_11_Jun_1923.jpg', alt='')
h1.title Farewell to Baseball Address
i.subtitle
strong.author Lou Gehrig
| , July 4, 1939, Yankee Stadium
p.text
| Fans, for the past two weeks you have been reading about a bad break I got. Yet today I
| consider myself the
| luckiest man on the face of the earth. I have been in ballparks for seventeen years and have never received
| anything but kindness and encouragement from you fans. Look at these grand men. Which of you wouldn’t
| consider it the highlight of his career to associate with them for even one day? Sure, I’m lucky. Who
| wouldn’t consider it an honor to have known Jacob Ruppert – also the builder of baseball’s greatest empire,
| Ed Barrow – to have spent the next nine years with that wonderful little fellow Miller Huggins – then to have
| spent the next nine years with that outstanding leader, that smart student of psychology – the best manager
| in baseball today, Joe McCarthy! Sure, I’m lucky. When the New York Giants, a team you would give your right
| arm to beat, and vice versa, sends you a gift, that’s something! When everybody down to the groundskeepers
| and those boys in white coats remember you with trophies, that’s something. When you have a wonderful
| mother-in-law who takes sides with you in squabbles against her own daughter, that’s something. When you have
| a father and mother who work all their lives so that you can have an education and build your body, it’s a
| blessing! When you have a wife who has been a tower of strength and shown more courage than you dreamed
| existed, that’s the finest I know. So I close in saying that I might have had a tough break – but I have an
| awful lot to live for!
hr.bar
.box.article-container
.box.article
.content
img#Chief-Joseph(src='', alt='')
h1.title Surrender Speech
i.subtitle
strong.author Chief Joseph
| , October 5, 1877, Montana Territory
p.text
| Tell General Howard I know his heart. What he told me before, I have it in my heart. I am
| tired of
| fighting. Our Chiefs are killed; Looking Glass is dead, Ta Hool Hool Shute is dead. The old men are all
| dead. It is the young men who say yes or no. He who led on the young men is dead. It is cold, and we have
| no blankets; the little children are freezing to death. My people, some of them, have run away to the
| hills, and have no blankets, no food. No one knows where they are – perhaps freezing to death. I want to
| have time to look for my children, and see how many of them I can find. Maybe I shall find them among the
| dead. Hear me, my Chiefs! I am tired; my heart is sick and sad. From where the sun now stands I will fight
| no more forever.
.box.article
.content
img#jfk(src='', alt='')
h1.title Inauguration Address
i.subtitle
strong.author John F. Kennedy
| , January 20, 1961, Washington, D.C.
p.text
| We’ve grown used to wonders in this century. It’s hard to dazzle us. But for 25 years the
| United States
| space program has been doing just that. We’ve grown used to the idea of space, and perhaps we forget that
| we’ve only just begun. We’re still pioneers. They, the members of the Challenger crew, were pioneers.
| And I want to say something to the school children of America who were watching the live coverage of the
| shuttle’s takeoff. I know it is hard to understand, but sometimes painful things like this happen. It’s all
| part of the process of exploration and discovery. It’s all part of taking a chance and expanding man’s
| horizons. The future doesn’t belong to the fainthearted; it belongs to the brave. The Challenger crew was
| pulling us into the future, and we’ll continue to follow them……
| The crew of the space shuttle Challenger honoured us by the manner in which they lived their lives. We will
| never forget them, nor the last time we saw them, this morning, as they prepared for the journey and waved
| goodbye and ‘slipped the surly bonds of earth’ to ‘touch the face of God.’
.box.article
.content
img#Alexander(src='', alt='')
h1.title Speech of Alexander
i.subtitle
strong.author Alexander the Great
| , 326 B.C., Hydaspes River, India
p.text
| I could not have blamed you for being the first to lose heart if I, your commander, had not
| shared in your
| exhausting marches and your perilous campaigns; it would have been natural enough if you had done all the
| work merely for others to reap the reward. But it is not so. You and I, gentlemen, have shared the labour
| and shared the danger, and the rewards are for us all. The conquered territory belongs to you; from your
| ranks the governors of it are chosen; already the greater part of its treasure passes into your hands, and
| when all Asia is overrun, then indeed I will go further than the mere satisfaction of our ambitions: the
| utmost hopes of riches or power which each one of you cherishes will be far surpassed, and whoever wishes
| to return home will be allowed to go, either with me or without me. I will make those who stay the envy of
| those who return.
script(async='', defer='', src='https://buttons.github.io/buttons.js')
@import url("https://fonts.googleapis.com/css?family=UnifrakturCook:700");
/* ⬇ class for test purpose ⬇ */
.testShadow {
box-shadow: 0 19px 38px rgba(0, 0, 0, 0.3), 0 15px 12px rgba(0, 0, 0, 0.22);
}
/* ⬇ code useful only for this pen ⬇ */
body {
margin: 0;
font-family: Georgia, serif;
}
hr {
width: 70%;
}
button {
display: block;
margin: auto;
border: none;
padding: 10px 20px;
border-radius: 3px;
color: #444;
font-size: 21px;
cursor: pointer;
}
.wrapper {
filter: brightness(10%);
width: 100%;
margin: 0;
display: grid;
grid-gap: 10px;
grid-template-columns: 3fr 2fr;
grid-template-rows: auto;
grid-template-areas:
"header header"
"main sidebar"
"article-container sidebar";
background-color: #fff;
color: #444;
}
.box {
color: #444;
padding: 20px;
}
.header {
grid-area: header;
text-align: center;
}
.header h1 {
font-family: "UnifrakturCook", cursive;
font-size: 48px;
margin: 0;
}
#main-article {
grid-area: main;
border-right: 1px solid #999;
}
#main-article .content {
padding: 0 20px;
-webkit-columns: 150px 3;
-moz-columns: 150px 3;
columns: 150px 3;
}
aside .content {
padding: 0 20px;
-webkit-columns: 150px 2;
-moz-columns: 150px 2;
columns: 150px 2;
}
.sidebar {
grid-area: sidebar;
}
.article-container {
grid-area: article-container;
display: grid;
grid-template-columns: 1fr 1fr 1fr;
}
.content {
margin: 40px 0 40px 0;
font-family: Georgia, serif;
font-weight: 400;
}
.main-article-image,
.The-luckiest-man,
.Demostenes,
#Chief-Joseph,
#jfk,
#Alexander {
border-radius: 3px;
display: block;
margin: auto;
}
.git {
margin: 20px;
}
.explain {
opacity: 0.9;
background: #444;
color: #fff;
position: fixed;
max-width: 500px;
max-height: 500px;
padding: 30px;
z-index: 999;
border-radius: 3px;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
top: 50%;
left: 50%;
transition: transform 1s;
transform: translate(-50%, -50%);
}
.explain h1,
.explain strong {
color: palegoldenrod;
}
@media screen and (max-width: 960px) {
.article-container {
grid-template-columns: 1fr 1fr;
}
}
@media screen and (max-width: 1024px) {
.wrapper {
grid-template-columns: auto;
grid-template-areas:
"header"
"main"
"sidebar"
"article-container";
}
}
// Scroll down for Debucsser configurations
// check out repo and docs at:
// https://github.com/lucagez/Debucsser
class Debucsser {
constructor(props) {
this.config = props || {};
this.color = this.config.color || 'palevioletred';
this.width = this.config.width || '3px';
this.style = this.config.style || 'solid';
this.customClass = this.config.customClass || null;
this.grayscaleOnDebug = this.config.grayscaleOnDebug || false;
this.grayscaleOnDebugAll = this.config.grayscaleOnDebugAll || false;
this.string = `${this.width} ${this.style} ${this.color}`;
this.mainKey = this.config.mainKey || 17;
this.secondKey = this.config.secondKey || 16;
this.init = this.init.bind(this);
this.debug = this.debug.bind(this);
this.debugAll = this.debugAll.bind(this);
this.stop = this.stop.bind(this);
this.addClass = this.addClass.bind(this);
this.labels = this.labels.bind(this);
this.createGlobalClass = this.createGlobalClass.bind(this);
this.removeGlobalClass = this.removeGlobalClass.bind(this);
}
init() {
// initialize invisible label element => we'll make it visible on selected keystroke
this.label = document.createElement('div');
this.label.classList.add('debucsser-label');
this.label.style = 'display: none;';
document.body.appendChild(this.label);
this.inject_label_style();
this.createDebugStyle();
this.debug();
this.globalStyle = this.createGlobalClass();
}
debug() {
console.log(this);
document.addEventListener('keydown', (key) => {
if (key.keyCode == this.mainKey) {
document.addEventListener('mousemove', this.labels, true);
document.addEventListener('mouseover', this.addClass, true);
document.addEventListener('keydown', this.debugAll, true);
}
this.stop();
});
}
stop() {
document.addEventListener('keyup', (key) => {
if (key.keyCode == this.mainKey) {
document.removeEventListener('mouseover', this.addClass, true);
document.removeEventListener('mousemove', this.labels, true);
this.label.style = 'display: none;';
}
})
}
addClass(over) {
over.target.classList.add(this.customClass ? this.customClass : 'debucsser');
document.addEventListener('mouseout', (out) => {
out.target.classList.remove(this.customClass ? this.customClass : 'debucsser');
}, true);
}
debugAll(key) {
if (key.keyCode == this.secondKey) {
document.body.appendChild(this.globalStyle);
document.addEventListener('keyup', this.removeGlobalClass, true)
}
}
createDebugStyle() {
const style = document.createElement('style');
style.innerHTML = `
.debucsser {
outline: ${this.string};
${this.config.grayscaleOnDebug && 'filter: grayscale(100%);'}
}
`;
document.body.appendChild(style);
}
createGlobalClass() {
const global = document.createElement('style');
console.log(this.config.grayscaleOnDebugAll)
global.innerHTML = `
* {
outline: ${this.string};
${this.config.grayscaleOnDebugAll && 'filter: grayscale(100%);'}
}
`;
return global;
}
removeGlobalClass(key) {
if (key.keyCode == this.secondKey) {
document.body.removeChild(this.globalStyle);
}
}
labels(e) {
if (e.target) {
const classList = e.target.classList ? e.target.classList.value.replace('debucsser', '') : undefined;
const id = e.target.id ? '#' + e.target.id : undefined;
const dimensions = e.target.getBoundingClientRect();
this.label.innerHTML = `
<h2>class: <strong>${classList || `¯\\_(ツ)_/¯`}</strong></h2>
<h2>id: <strong>${id || `¯\\_(ツ)_/¯`}</strong></h2>
<h2><strong>${dimensions.width.toFixed(0)}px</strong> × <strong>${dimensions.height.toFixed(0)}px</strong></h2>
`;
this.label.style = `display: block; top:${e.clientY + 20}px; left:${e.clientX + 20}px;`;
} else {
this.label.style = 'display: none;';
}
}
inject_label_style() {
const style = document.createElement('div');
style.innerHTML = `
<style>
.debucsser-label {
position: fixed;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
padding: 10px 20px;
background: #333;
border-radius: 3px;
color: #f9f9f9;
opacity: 0.9;
z-index: 999;
}
.debucsser-label strong {
color: palevioletred;
}
</style>`;
document.body.appendChild(style);
}
}
// init Debucsser
// comment out config properties to customize how Debucsser behave
const config = {
// color: 'palevioletred',
// width: '4px',
// grayscaleOnDebugAll: true,
// customClass: 'testShadow',
}
const debug = new Debucsser(config).init();
// demo initial explanation
const explain = document.querySelector('.explain');
explain.querySelector('button').addEventListener('click', () => {
explain.style.transform = 'translateX(2000px)';
document.querySelector('.wrapper').style.filter = 'none';
});
Also see: Tab Triggers