Повторение фонового изображения по осям x и y с использованием ключевого слова - пример html js css



Книга Повторение фонового изображения по осям x и y с использованием ключевого слова

Повторение фонового изображения по осям x и y с использованием ключевого слова (HTML код)


<div class="wrapper">
  <h2>Repeating a background-image across both the x axis and the y axis using one keyword</h2>
  <figure id="demoCallout" class="callout">
    <p>When we repeat a background image using one of the predefined keywords the background-property accepts once  –<code>no-repeat</code>,&nbsp;<code>round</code>,&nbsp;<code>space</code>,&nbsp;<code>repeat-x</code>,&nbsp;<code>repeat-y</code>,&nbsp;or&nbsp;<code>repeat</code> (the default)–the tiling behavior associated with that keyword are applied to the x and y axes.</p>
  </figure>
  <div id="demoAndCodeSnippetBox">

    <div id="demoBox" resizeable></div>
  <div>
    <div id="keywordPanel" class="configuration-panel">
    </div>
  </div>
  </div>
  <div id="imageControls">
    <div id="imageSelection">
      <label for="imageSelector">Image</label>
      <select id="imageSelector" name="Available placeholder images you can use">
        <option value="">Select an image to render in the CSS box</option>
      </select>
    </div>
    
    <div id="imageBackgroundSizeControls">
      <label for="imgSizeSlider">Image Background Size (using percentage values)</label>
      <mwc-slider id="imgSizeSlider" min="10" max="100" value="25" pin markers step="1"></mwc-slider>
    </div>
  </div>
  
</div>

Повторение фонового изображения по осям x и y с использованием ключевого слова (CSS код)



/* PULL IN FONTS AND RESET */
@import url("https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,500;0,700;1,400;1,500&display=swap");
@import url("https://unpkg.com/modern-css-reset/dist/reset.min.css");

/* SETTINGS */
:root {
  --color-primary: #3740ff;
  --color-primary-dark: #272eb5;
  --color-primary-light: #3740ff;
  --color-primary-x-light: #e8f0fe;
  --color-light: #ffffff;
  --color-dark: #202124;
  --color-off-white: #f3f4f4;
  --color-mid: #5f6368;
  --color-mid-dark: #3c4043;
  --color-stroke: #dadce0;
  --metric-gutter: 1.5rem;
  --metric-box-spacing: 1rem;
  --metric-radius: 3px;
  --generic-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3),
    0px 2px 6px 2px rgba(60, 64, 67, 0.15);
  --font-mono: SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
  --mdc-button-horizontal-padding: 0;
}

/* PROP-CONTROLLED UTIL CLASSES */
.color-primary {
  color: var(--color-primary);
}

.color-primary-dark {
  color: var(--color-primary-dark);
}

.color-primary-light {
  color: var(--color-primary-light);
}

.color-primary-x-light {
  color: var(--color-primary-x-light);
}

.color-light {
  color: var(--color-light);
}

.color-dark {
  color: var(--color-dark);
}

.color-off-white {
  color: var(--color-off-white);
}

.color-mid {
  color: var(--color-mid);
}

.color-mid-dark {
  color: var(--color-mid-dark);
}

.bg-primary {
  background: var(--color-primary);
}

.bg-primary-dark {
  background: var(--color-primary-dark);
}

.bg-primary-light {
  background: var(--color-primary-light);
}

.bg-primary-x-light {
  background: var(--color-primary-x-light);
}

.bg-light {
  background: var(--color-light);
}

.bg-dark {
  background: var(--color-dark);
}

.bg-off-white {
  background: var(--color-off-white);
}

.bg-mid {
  background: var(--color-mid);
}

.bg-mid-dark {
  background: var(--color-mid-dark);
}

/* GLOBAL STYLES */
body {
  min-height: 100vh;
  padding: 2rem 0;
  display: flex;
  flex-direction: column;
  font-family: "Roboto", Arial, Helvetica, sans-serif;
  background: var(--color-light);
  color: var(--color-dark);
  line-height: 1.55;
  letter-spacing: 0.03ch;
}

main {
  flex: auto;
}

a:not([class]) {
  color: var(--color-primary);
}

a:hover {
  text-decoration: none;
}

:is(h1, h2, h3) {
  font-weight: 500;
  line-height: 1.2;
  max-width: 50ch;
}

h1 {
  font-size: 2.25rem;
}

h2 {
  font-size: 1.75rem;
  color: var(--color-mid-dark);
}

h3 {
  font-size: 1.25rem;
}

:is(p, li, blockquote, dl) {
  max-width: 65ch;
}

ul {
  padding: 0 0 0 1.3rem;
}

li + li {
  margin-top: 1rem;
}

/*
code {
  padding: 0.125em 0.25em;
  background: var(--color-off-white);
  border: 1px solid var(--color-stroke);
  font-family: var(--font-mono);
  font-size: 0.85em;
  hyphens: none;
  tab-size: 2;
  text-align: left;
  word-spacing: normal;
  word-break: normal;
  word-wrap: normal;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
*/

figcaption {
  margin-top: 0.5em;
  font-weight: normal;
  text-align: left;
}

select {
  padding: 0.5rem;
  min-width: 12rem;
  font: inherit;
  border: 1px solid var(--color-stroke);
}

select:focus {
  border-color: var(--color-primary);
}

hr {
  border: 0;
  border-top: 1px solid var(--color-stroke);
  margin: 4rem auto !important; /* Gotta be sure this overrides flow rules etc */
}

label::after {
  content: "\A";
  white-space: pre;
}

::marker {
  color: var(--color-mid);
  font-size: 1.5em;
}

/* GENERIC UTILITIES */

/* https://piccalil.li/quick-tip/flow-utility */
.flow > * + * {
  margin-top: var(--flow-space, 2em);
}

/* https://piccalil.li/quick-tip/use-css-clamp-to-create-a-more-flexible-wrapper-utility */
.wrapper {
  width: 90vw;
  width: clamp(16rem, 90vw, 70rem);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--metric-gutter);
  padding-right: var(--metric-gutter);
  position: relative;
}

/* ELEMENTS */
.box {
  padding: var(--metric-box-spacing);
  border: 1px solid var(--color-stroke);
  box-shadow: var(--generic-shadow);
  font-weight: 500;
  text-align: center;
  max-width: 40rem;
}

.box:not([class*="bg-"]) {
  background: var(--color-off-white);
}

.button,
button {
  display: inline-flex;
  align-items: center;
  justify-items: center;
  background: var(--color-primary);
  border: 1px solid var(--color-primary);
  border-radius: var(--metric-radius);
  color: var(--color-light);
  cursor: pointer;
  font: inherit;
  padding: 1rem;
  position: relative;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.1ch;
  transition: background-color 0.2s, box-shadow 0.2s;
  overflow: hidden;
  position: relative;
  white-space: nowrap;
  box-shadow: none;
}

.button:hover,
button:hover {
  box-shadow: var(--generic-shadow);
  background: var(--color-primary-light);
}

.button[data-type="secondary"],
button[data-type="secondary"] {
  background: var(--color-light);
  color: var(--color-dark);
  border-color: var(--color-stroke);
}

.button[data-type="secondary"]:hover,
button[data-type="secondary"]:hover {
  background: var(--color-off-white);
}

/* CALLOUT */
.callout {
  padding: var(--metric-box-spacing) var(--metric-box-spacing)
    var(--metric-box-spacing) 3rem;
  background: var(--color-primary-x-light);
  border: 1px solid var(--color-primary-light);
  color: var(--color-primary-dark);
  position: relative;
  max-width: 40rem;
}

.callout::before {
  content: "";
  background-image: url('data:image/svg+xml;utf8,');
  background-size: cover;
  width: 1.25rem;
  height: 1.25rem;
  display: block;
  position: absolute;
  top: var(--metric-box-space);
  left: 1rem;
}

.callout p + p {
  margin-top: 1em;
}

.callout a {
  color: var(--color-primary-dark);
  font-weight: bold;
}

/* TOGGLE */
.toggle {
  --metric-toggle-thumb-size: 1rem;
  --metric-toggle-thumb-space: 0.25rem;

  position: relative;
  display: inline-flex;
  align-items: center;
}

.toggle__element {
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: var(--metric-toggle-thumb-size);
  width: 1em;
  height: 1em;
}

.toggle__decor {
  display: block;
  position: relative;
  overflow: hidden;
  width: calc(
    (var(--metric-toggle-thumb-size) * 2) +
      (var(--metric-toggle-thumb-space) * 2)
  );
  height: calc(
    var(--metric-toggle-thumb-size) + (var(--metric-toggle-thumb-space) * 2)
  );
  background: var(--color-mid);
  margin-left: 0.5rem;
  border-radius: var(--metric-toggle-thumb-size);
  box-sizing: content-box;
  border: 1px solid var(--color-light);
}

.toggle__thumb {
  display: grid;
  place-items: center;
  width: var(--metric-toggle-thumb-size);
  height: var(--metric-toggle-thumb-size);
  border-radius: var(--metric-toggle-thumb-size);
  background: linear-gradient(
      229.84deg,
      rgba(255, 255, 255, 0) 14.29%,
      rgba(48, 48, 48, 0.15) 81.82%
    ),
    #ffffff;
  box-shadow: var(--generic-shadow);
  position: absolute;
  top: var(--metric-toggle-thumb-space);
  left: var(--metric-toggle-thumb-space);
  transform: none;
  transition: transform 200ms cubic-bezier(1, 0, 0.55, 0.85);
  will-change: transform;
  z-index: 1;
}

.toggle__thumb::before {
  content: "";
  display: none;
  width: calc(
    var(--metric-toggle-thumb-size) - var(--metric-toggle-thumb-space)
  );
  height: calc(
    var(--metric-toggle-thumb-size) - var(--metric-toggle-thumb-space)
  );
  border: 1px solid var(--color-primary-light);
  border-radius: calc(
    var(--metric-toggle-thumb-size) - var(--metric-toggle-thumb-space)
  );
}

.toggle__thumb::before {
  content: "";
  display: none;
  width: calc(
    var(--metric-toggle-thumb-size) - var(--metric-toggle-thumb-space)
  );
  height: calc(
    var(--metric-toggle-thumb-size) - var(--metric-toggle-thumb-space)
  );
  border: 1px solid var(--color-primary);
  border-radius: calc(
    var(--metric-toggle-thumb-size) - var(--metric-toggle-thumb-space)
  );
}

.toggle__decor:hover .toggle__thumb {
  margin-left: 1px;
}

:checked + .toggle__decor:hover .toggle__thumb {
  margin-left: -1px;
}

:checked + .toggle__decor {
  background: var(--color-primary-light);
}

:checked + .toggle__decor .toggle__thumb {
  transform: translateX(var(--metric-toggle-thumb-size)) rotate(270deg);
}

:focus + .toggle__decor:not(:hover) .toggle__thumb::before {
  display: block;
}

:disabled + .toggle__decor {
  filter: grayscale(1) brightness(1.5);
  cursor: not-allowed;
}

/* DIMENSIONS LABEL */
.dimension-label {
  position: relative;
  text-align: center;
  font-family: var(--font-mono);
  color: var(--color-primary-dark);
}

.dimension-label::before {
  content: "";
  width: 134px;
  height: 8px;
  background-image: url('data:image/svg+xml;utf8,');
  background-position: center center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.dimension-label > * {
  display: inline-block;
  padding: 0.25em;
  background: var(--color-light);
  position: relative;
  z-index: 1;
}

.dimension-label[data-orientation="vertical"] {
  writing-mode: vertical-rl;
  text-orientation: mixed;
}

.dimension-label[data-orientation="vertical"]::before {
  transform: translate(-50%, -50%) rotate(90deg);
}

/* CLUSTER LAYOUT */
.cluster {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  margin: calc(var(--metric-gutter) / 2 * -1);
}

.cluster > * {
  margin: calc(var(--metric-gutter) / 2);
}

/* SIDEBAR LAYOUT */

.sidebar {
  --sidebar-min-content-width: 50%;

  display: flex;
  flex-wrap: wrap;
  margin: calc(var(--metric-gutter) / 2 * -1);
}

.sidebar > * {
  margin: calc(var(--metric-gutter) / 2);
  flex-grow: 1;
}

.sidebar > :last-child {
  flex-basis: 0;
  flex-grow: 999;
  min-width: calc(var(--sidebar-min-content-width) - var(--metric-gutter));
}

/* SWITCHER LAYOUT */

.switcher {
  --switcher-threshold: 40rem;

  display: flex;
  flex-wrap: wrap;
  margin: calc((var(--metric-gutter) / 2) * -1);
}

.switcher > * {
  flex-grow: 1;
  flex-basis: calc(
    (var(--switcher-threshold) - (100% - var(--metric-gutter))) * 999
  );
  margin: calc(var(--metric-gutter) / 2);
}

.switcher > :nth-last-child(n + 5),
.switcher > :nth-last-child(n + 5) ~ * {
  flex-basis: 100%;
}

/* Demo Unique Styles */

.wrapper h2 {
  max-width: 100%;
}

#demoCallout, #demoCallout > * {
  max-width: 100%;
}

#demoCallout {
  margin-top: 1rem;
}


*,
*:before,
*:after {
  box-sizing: border-box;
}

#demoBox {
  border: 0.5px solid hsla(0deg, 0%, 60%, 0.5);
  aspect-ratio: 1/1;
  background: url("https://images.unsplash.com/photo-1493903451767-ceba1e22f051?auto=format&fit=crop&w=3034&q=80");
  /* have background-size be within reason within the bounds of box but still allow regular tiling to occur on applicable images */
  background-size: 25%;
  background-position: 50% 50%;
  width: 100%;
}

/* TODO: Make one-column by default */
#demoAndCodeSnippetBox {
  display: grid;
  grid-template-columns: 1fr 2.618fr;
  grid-gap: 1rem;
  margin: 2rem 0;
  width: 100%;
}

#demoAndCodeSnippetBox pre,
#demoAndCodeSnippetBox .code-toolbar {
  height: 100%;
  margin: 0;
  white-space: pre-wrap;
  width: 100%;
  overflow: auto;
}

label[for="imageSelector"] {
  display: block;
  margin-bottom: 0.25rem;
}

iron-selector > *:not([selected-configuration]) {
  display: none;
}

.configuration-panel {
  padding: 1rem 0;
}

#keywordPanel {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 1rem;
  align-items: center;
  height: 100%;
}

#imageControls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 1rem;
}

mwc-button {
  margin-top: 0;
}

mwc-slider {
  width: 100%;
}


Повторение фонового изображения по осям x и y с использованием ключевого слова (JS код)



var _a;
// Note: Deliberately iterative; in normal circumstances this would be done with a State machine & functional/object-oriented programming. 
import "https://unpkg.com/@material/mwc-button@0.22.1/mwc-button.js?module";
import "https://unpkg.com/@material/mwc-slider@0.22.1/mwc-slider.js?module";
console.clear();
const BACKGROUND_REPEAT_KEYWORDS = [
    'repeat',
    'no-repeat',
    'space',
    "round",
    "repeat-x",
    "repeat-y"
];
const IMAGES = [
    {
        url: "https://images.unsplash.com/photo-1536707076730-0615b7f5b49a?auto=format&fit=crop&w=690&q=80",
        credit: "Caique Silva",
        group: "People",
        label: "Woman gazing at sky on a beach",
    },
    {
        url: "",
        credit: "Caique Silva",
        group: "People",
        label: "Woman gazing at sky on a beach (Data URI)",
    },
    {
        url: "https://images.unsplash.com/photo-1484723091739-30a097e8f929?auto=format&fit=crop&w=1547&q=80",
        group: "Food",
        label: "French toast with banana & blueberry topping glazed with honey",
        credit: null,
    },
    {
        url: "",
        group: "Food",
        label: "French toast with banana & blueberry topping glazed with honey (Data URI)",
        credit: null,
    },
    {
        url: "https://images.unsplash.com/photo-1530692662486-2d0e8bb0746f?auto=format&fit=crop&w=1834&q=80",
        credit: "Blake Cheek",
        group: "People",
        label: "Man in a pink hoody hanging on a street pole",
    },
    {
        url: "https://images.unsplash.com/photo-1493903451767-ceba1e22f051?auto=format&fit=crop&w=3034&q=80",
        credit: "Dimitar Belchev",
        group: "People",
        label: "Three people hugging",
    },
    {
        url: "https://images.unsplash.com/photo-1524272332618-3a94122bb0c1?auto=format&fit=crop&w=690&q=80",
        credit: "Matthew Cabret",
        group: "Animals",
        label: "Flamingos in Tropical Location",
    },
];
let BACKGROUND_IMAGE = (_a = IMAGES[0]) === null || _a === void 0 ? void 0 : _a.url;
let BACKGROUND_REPEAT = 'repeat';
let BACKGROUND_SIZE = "25%";
const GroupedImages = IMAGES.reduce((acc, val) => {
    const group = val.group;
    if (!group) {
        return acc;
    }
    else if (group in acc) {
        acc[group].push(val);
        return acc;
    }
    else {
        acc[group] = [val];
        return acc;
    }
}, {});
// console.log(GroupedImages);
const optgroupFragment = new DocumentFragment();
Object.entries(GroupedImages).forEach(([groupLabel, images]) => {
    console.log(groupLabel, images.length);
    const optgroup = document.createElement("optgroup");
    optgroup.setAttribute("label", groupLabel);
    const imagesFragment = new DocumentFragment();
    images.forEach((image) => {
        const option = document.createElement("option");
        option.setAttribute("value", image.url);
        option.textContent = image.label;
        option.dataset.credit = image.credit;
        imagesFragment.append(option);
    });
    optgroup.append(imagesFragment);
    optgroupFragment.appendChild(optgroup);
});
imageSelector.appendChild(optgroupFragment);
imageSelector.addEventListener("change", (event) => {
    window.requestAnimationFrame(() => {
        const url = event.target.value;
        if (url) {
            BACKGROUND_IMAGE = url;
            demoBox.style.backgroundImage = `url('${url}')`;
            console.log(demoBox.style.backgroundImage);
        }
        // TODO: Fetch & render credit information
    });
});
imgSizeSlider.addEventListener('change', (e) => {
    var _a;
    BACKGROUND_SIZE = `${(_a = e.detail.value) !== null && _a !== void 0 ? _a : 25}%`;
    demoBox.style.backgroundSize = BACKGROUND_SIZE;
});
const reactToKeyword = (keyword) => {
    BACKGROUND_REPEAT = keyword;
    demoBox.style.backgroundRepeat = keyword;
};
const changeCSSBoxUsingKeyword = (keyword) => {
    keyword = keyword === null || keyword === void 0 ? void 0 : keyword.toLowerCase();
    if (BACKGROUND_REPEAT_KEYWORDS.includes(keyword)) {
        reactToKeyword(keyword);
    }
    else {
        console.warn("Default value for background-repeat used due to invalid input in panel");
        reactToKeyword("top left");
    }
};
const fragment = new DocumentFragment();
BACKGROUND_REPEAT_KEYWORDS.forEach(keyword => {
    const button = document.createElement('mwc-button');
    button.classList.add('bg-keyword-button');
    button.setAttribute('action', keyword);
    button.setAttribute('raised', '');
    button.setAttribute('aria-label', `Set background repeat of CSS Box to ${keyword}`);
    button.textContent = keyword;
    button.addEventListener("click", (e) => {
        var _a;
        const action = (_a = e.target.getAttribute("action")) !== null && _a !== void 0 ? _a : "auto";
        changeCSSBoxUsingKeyword(action);
    });
    fragment.append(button);
});
keywordPanel.append(fragment);
//# sourceURL=pen.js
    

Повторение фонового изображения по осям x и y с использованием ключевог

117   0  
    Ничего не найдено.

Добавить ответ:
Отменить.