Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
290 views
in Technique[技术] by (71.8m points)

wordpress - How do I get the width and height of an image in a function _content_template()?

protected function render() {
    $settings = $this->get_settings_for_display();

    // Get image URL
    echo '<img src="' . $settings['image']['url'] . '">';

    // Get image 'thumbnail' by ID
    echo wp_get_attachment_image( $settings['image']['id'], 'thumbnail' );

    // Get image HTML
    echo ElementorGroup_Control_Image_Size::get_attachment_image_html( $settings );
}

protected function _content_template() {
?>
    <img src="{{ settings.image.url }}">
    <?php
}

I was able to get the width and height values in php, but I can't get it for the _content_template() function

$media_image = wp_get_attachment_image_src( $settings['media_image']['id'], 'full' );
$image_width = $media_image[1];
$image_height = $media_image[2];
question from:https://stackoverflow.com/questions/65938553/how-do-i-get-the-width-and-height-of-an-image-in-a-function-content-template

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

You have to use the method add_render_attribute to add this into the backbonejs part i.e. inside the _content_template:

$this->add_render_attribute( 'image', 'src', $settings['image']['url'] );

add_render_attribute for reference

Once you added the attribute you can access it in _content_template like this: settings.image.url

settings.image.url for reference

Therefore, the thing you need to add is add_render_attribute method inside the method render to access in _content_template

Mainly focus on this particular snippet of content template method:

var image = {
    id: settings.image.id,
    url: settings.image.url,
    size: settings.thumbnail_size,
    dimension: settings.thumbnail_custom_dimension,
    model: view.getEditModel()
};
var image_url = elementor.imagesManager.getImageUrl( image );
var imageHtml = '<img src="' + image_url + '" class="elementor-animation-' + settings.hover_animation + '" />';

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...