Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
Puchar WPB
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

Jak dynamicznie zmienić szerokość i wysokość oEmbed w WordPress

Czy chcesz dynamicznie zmieniać szerokość i wysokość oEmbed w WordPress?

Domyślnie WordPress świetnie radzi sobie z osadzaniem filmów i innych elementów oEmbeds w twoich wpisach i na stronach. Czasami jednak możesz chcieć dynamicznie zmienić szerokość i wysokość osadzania.

W tym artykule pokażemy, jak dynamicznie zmieniać szerokość i wysokość oEmbed w WordPress.

Dynamically changing oEmbed width and height in WordPress

Dlaczego warto ustawić dynamiczną szerokość i wysokość ombed w WordPress?

WordPress ułatwia osadzanie treści stron trzecich w twoich wpisach i stronach za pomocą technologii o nazwie oEmbed.

Pozwala to na łatwe osadzanie filmów z YouTube, filmów z TikTok, tweetów i innych treści w WordPress. Najlepsze jest to, że treści te nie są hostowane na twojej witrynie internetowej WordPress, co oszczędza zasoby serwera i poprawia wydajność WordPress.

Fixed width oEmbed in WordPress

Domyślnie WordPress wykonuje świetną robotę, automatycznie dostosowując wysokość i szerokość osadzanych treści, aby pasowały do twoich wpisów i stron.

Niektórzy użytkownicy mogą jednak chcieć zmienić to domyślne zachowanie. Na przykład, można ustawić inną domyślną szerokość i wysokość osadzania dla strony głównej i poszczególnych artykułów.

Jest to przydatne, gdy korzystasz z niestandardowego układu strony głównej lub pracujesz nad własnym projektem motywu.

Biorąc to pod uwagę, przyjrzyjmy się, jak łatwo ustawić dynamiczną szerokość i wysokość dla treści oEmbed w WordPress.

Metoda 1. Ustawianie szerokości i wysokości dynamicznego osadzania w WordPress

Ta metoda wymaga dodania własnego kodu do twojej witryny internetowej WordPress. Jeśli nie robiłeś tego wcześniej, zapoznaj się z naszym przewodnikiem na temat łatwego wklejania fragmentów kodu z sieci do WordPressa.

W tej metodzie użyjemy tagów warunkowych WordPress, aby wykryć, która strona WordPress jest zobaczona, a następnie odpowiednio zmienić domyślną szerokość i wysokość oEmbed.

Wystarczy dodać poniższy kod do pliku functions. php twojego motywu, wtyczki specyficznej dla witryny lub wtyczki fragmentów kodu.

//Custom oEmbed Size
function wpb_oembed_defaults($embed_size) {
if(is_front_page()) {
        $embed_size['width'] = 940;
        $embed_size['height'] = 600;
}
else {
    $embed_size['width'] = 600;
        $embed_size['height'] = 338;
}
    return $embed_size;
}
add_filter('embed_defaults', 'wpb_oembed_defaults');

Zalecamy dodanie tego kodu za pomocą WPCode, najlepszej wtyczki do fragmentów kodu WordPress. Jest to najprostszy sposób na dodanie własnego kodu w WordPressie bez edytowania pliku functions.php twojego motywu.

WPCode

Dzięki tej metodzie nie musisz martwić się o uszkodzenie twojej witryny. Ponadto, jeśli zmienisz swój motyw WordPress, będziesz mógł zachować wszystkie własne konfiguratory.

Aby rozpocząć, należy zainstalować i włączyć bezpłatną wtyczkę WPCode. Aby uzyskać instrukcje krok po kroku, zapoznaj się z naszym przewodnikiem na temat instalacji wtyczki WordPress.

Po włączeniu wtyczki, przejdź do Code Snippets + Add Snippet z twojego kokpitu administracyjnego WordPress.

Następnie znajdź opcję „Add Your Custom Code (New Snippet)” i kliknij przycisk „Use snippet”.

Add a new custom code snippet in WPCode

Następnie wystarczy skopiować i wkleić fragment kodu z góry do pola „Podgląd kodu”. Musisz również wybrać „Fragment kodu PHP” jako rodzaj kodu z rozwijanej listy po prawej stronie.

Paste custom oEmbed code in WPCode

Następnie wystarczy przełączyć przełącznik u góry ekranu z „Nieaktywny” na „Aktywny” i kliknąć przycisk „Zapisz fragment kodu”.

Save and activate your custom code snippet

Możesz użyć dowolnego z dostępnych tagów warunkowych WordPress, aby wykryć różne scenariusze.

Oto kolejny przykład, w którym zmieniamy domyślną szerokość oEmbed dla własnej strony docelowej.

function wpb_oembed_defaults($embed_size) {
if( is_page( 42 ) ) {
        $embed_size['width'] = 940;
        $embed_size['height'] = 600;
}
else {
    $embed_size['width'] = 600;
        $embed_size['height'] = 338;
}
    return $embed_size;
}
add_filter('embed_defaults', 'wpb_oembed_defaults');

Jak widać, kod ten po prostu ustawia inną domyślną szerokość i wysokość dla określonego identyfikatora strony.

Metoda 2. Używanie CSS do ustawiania dynamicznej szerokości i wysokości oEmbed

WordPress automatycznie dodaje domyślne klasy CSS do różnych obszarów twojej witryny internetowej.

Te klasy CSS mogą być następnie wykorzystane do zmiany wyglądu osadzanych elementów w określonych obszarach twojej witryny internetowej.

Na przykład, możesz znaleźć klasy CSS, takie jak identyfikator strony, wpis, kategoria, tag i wiele innych w twoim motywie WordPress. Możesz znaleźć te klasy CSS za pomocą narzędzia Inspect.

CSS class for post and page

Podobnie, WordPress dodaje również klasy CSS do osadzania bloków w twoich wpisach i stronach. Ponownie, użyjesz narzędzia Inspect, aby dowiedzieć się, które klasy są używane przez blok osadzania.

CSS classes for embed blocks

Gdy masz już te klasy CSS, możesz ich użyć do ustawienia dynamicznej wysokości i szerokości dla oEmbeds. Na przykład w poniższym przykładowym kodzie ustawiamy dynamiczną szerokość i wysokość dla bloku osadzania Pinterest na określonym identyfikatorze wpisu.

article#post-79 .wp-block-embed-pinterest {
    max-width: 200px!important;
    max-height: 400px!important;
}

Możesz wypróbować swój kod CSS, dodając własny CSS w konfiguratorze motywu. Gdy będziesz zadowolony, nie zapomnij zapisać i opublikować twoich zmian.

Mamy nadzieję, że te dwie metody pomogły ci dowiedzieć się, jak łatwo ustawić dynamiczną szerokość i wysokość oEmbed w WordPress. Możesz również zapoznać się z tymi przydatnymi wskazówkami, sztuczkami i hackami WordPress lub sprawdzić nasz wybór najlepszych wtyczek mediów społecznościowych dla WordPress.

If you liked this article, then please subscribe to our YouTube Channel for WordPress video tutorials. You can also find us on Twitter and Facebook.

Ujawnienie: Nasze treści są wspierane przez czytelników. Oznacza to, że jeśli klikniesz na niektóre z naszych linków, możemy otrzymać prowizję. Zobacz jak WPBeginner jest finansowany, dlaczego to ma znaczenie i jak możesz nas wspierać. Oto nasz proces redakcyjny.

Avatar

Editorial Staff at WPBeginner is a team of WordPress experts led by Syed Balkhi with over 16 years of experience in WordPress, Web Hosting, eCommerce, SEO, and Marketing. Started in 2009, WPBeginner is now the largest free WordPress resource site in the industry and is often referred to as the Wikipedia for WordPress.

Najlepszy zestaw narzędzi WordPress

Uzyskaj BEZPŁATNY dostęp do naszego zestawu narzędzi - zbiór produktów i zasobów związanych z WordPressem, które każdy profesjonalista powinien mieć!

Reader Interactions

9 komentarzyZostaw odpowiedź

  1. Syed Balkhi

    Hey WPBeginner readers,
    Did you know you can win exciting prizes by commenting on WPBeginner?
    Every month, our top blog commenters will win HUGE rewards, including premium WordPress plugin licenses and cash prizes.
    You can get more details about the contest from here.
    Start sharing your thoughts below to stand a chance to win!

  2. Nick

    Can we include % in width value? ex. $embed_size[’width’] = 100%;

  3. Joseph Nirmal

    Iam using genesis child theme (news). How to expand the width of my theme.

    • WPBeginner Support

      using CSS you can expand width of your theme. For more specific you should ask in Genesis support forums.

      Administrator

  4. Marc

    Does „$embed_size” replace or alter „$content_width”?

      • Marc

        I got the REQUIRED message from the theme-check plugin to set $content_width. So you are correct.

  5. M Asif Rahman

    Nice and easy. Thanks.

  6. Gregg

    What if you wanted text to flow around the oembed? alignleft, alignright

Zostaw odpowiedź

Dziękujemy za pozostawienie komentarza. Pamiętaj, że wszystkie komentarze są moderowane zgodnie z naszymi polityka komentarzy, a Twój adres e-mail NIE zostanie opublikowany. NIE używaj słów kluczowych w polu nazwy. Przeprowadźmy osobistą i konstruktywną rozmowę.