Bootstrap 4 cols not working in Angular Component












0














If I have an angular component "sidebar" with bootstrap col inside it the grid breaks.



My app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<app-sidebar></app-sidebar>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<div class="col-md-3 sidebar">Sidebar Content</div>


but if I use the following it works:



my app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div class="col-md-3 sidebar">
<app-sidebarfilter></app-sidebarfilter>
</div>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<p>sidebar content</p>


What is going on, in many instances it would be beneficial to have the col in components. But why isn't it working like I would expect? I don't remember this from he last time I worked with angular a year or two ago.



Using:
bootstrap 4
angular 7.0










share|improve this question






















  • can you make a functional example with the problem?
    – ppollono
    Nov 21 at 11:32










  • please see above
    – WindDude
    Nov 21 at 18:25
















0














If I have an angular component "sidebar" with bootstrap col inside it the grid breaks.



My app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<app-sidebar></app-sidebar>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<div class="col-md-3 sidebar">Sidebar Content</div>


but if I use the following it works:



my app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div class="col-md-3 sidebar">
<app-sidebarfilter></app-sidebarfilter>
</div>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<p>sidebar content</p>


What is going on, in many instances it would be beneficial to have the col in components. But why isn't it working like I would expect? I don't remember this from he last time I worked with angular a year or two ago.



Using:
bootstrap 4
angular 7.0










share|improve this question






















  • can you make a functional example with the problem?
    – ppollono
    Nov 21 at 11:32










  • please see above
    – WindDude
    Nov 21 at 18:25














0












0








0







If I have an angular component "sidebar" with bootstrap col inside it the grid breaks.



My app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<app-sidebar></app-sidebar>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<div class="col-md-3 sidebar">Sidebar Content</div>


but if I use the following it works:



my app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div class="col-md-3 sidebar">
<app-sidebarfilter></app-sidebarfilter>
</div>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<p>sidebar content</p>


What is going on, in many instances it would be beneficial to have the col in components. But why isn't it working like I would expect? I don't remember this from he last time I worked with angular a year or two ago.



Using:
bootstrap 4
angular 7.0










share|improve this question













If I have an angular component "sidebar" with bootstrap col inside it the grid breaks.



My app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<app-sidebar></app-sidebar>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<div class="col-md-3 sidebar">Sidebar Content</div>


but if I use the following it works:



my app.component.html



<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div class="col-md-3 sidebar">
<app-sidebarfilter></app-sidebarfilter>
</div>
<div class="col-md-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>


my sidebar.component.html



<p>sidebar content</p>


What is going on, in many instances it would be beneficial to have the col in components. But why isn't it working like I would expect? I don't remember this from he last time I worked with angular a year or two ago.



Using:
bootstrap 4
angular 7.0







angular twitter-bootstrap responsive-design






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 20 at 17:53









WindDude

488




488












  • can you make a functional example with the problem?
    – ppollono
    Nov 21 at 11:32










  • please see above
    – WindDude
    Nov 21 at 18:25


















  • can you make a functional example with the problem?
    – ppollono
    Nov 21 at 11:32










  • please see above
    – WindDude
    Nov 21 at 18:25
















can you make a functional example with the problem?
– ppollono
Nov 21 at 11:32




can you make a functional example with the problem?
– ppollono
Nov 21 at 11:32












please see above
– WindDude
Nov 21 at 18:25




please see above
– WindDude
Nov 21 at 18:25












1 Answer
1






active

oldest

votes


















0














make the sidebar component to be like this, first level inside a .row MUST be col-SOMETHING






<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div app-sidebarfilter class="col-xs-3">sidebar</div>
<div class="col-xs-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>








share|improve this answer





















  • so you're suggesting changing the component selector to an attribute? That doesn't solve the problem, of wanting to put the col class inside the *.component.html. Strange the requirement for the col class to be immediately after the row class seems to be an issue with bootstrap 4, that wasn't present in 3
    – WindDude
    Nov 21 at 18:32













Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53398775%2fbootstrap-4-cols-not-working-in-angular-component%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









0














make the sidebar component to be like this, first level inside a .row MUST be col-SOMETHING






<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div app-sidebarfilter class="col-xs-3">sidebar</div>
<div class="col-xs-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>








share|improve this answer





















  • so you're suggesting changing the component selector to an attribute? That doesn't solve the problem, of wanting to put the col class inside the *.component.html. Strange the requirement for the col class to be immediately after the row class seems to be an issue with bootstrap 4, that wasn't present in 3
    – WindDude
    Nov 21 at 18:32


















0














make the sidebar component to be like this, first level inside a .row MUST be col-SOMETHING






<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div app-sidebarfilter class="col-xs-3">sidebar</div>
<div class="col-xs-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>








share|improve this answer





















  • so you're suggesting changing the component selector to an attribute? That doesn't solve the problem, of wanting to put the col class inside the *.component.html. Strange the requirement for the col class to be immediately after the row class seems to be an issue with bootstrap 4, that wasn't present in 3
    – WindDude
    Nov 21 at 18:32
















0












0








0






make the sidebar component to be like this, first level inside a .row MUST be col-SOMETHING






<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div app-sidebarfilter class="col-xs-3">sidebar</div>
<div class="col-xs-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>








share|improve this answer












make the sidebar component to be like this, first level inside a .row MUST be col-SOMETHING






<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div app-sidebarfilter class="col-xs-3">sidebar</div>
<div class="col-xs-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>








<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div app-sidebarfilter class="col-xs-3">sidebar</div>
<div class="col-xs-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>





<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
<div id="wrapper" style="padding-top: 80px;">
<app-header></app-header>
<app-searchrow></app-searchrow>
<div class="main-container">
<div class="container">
<div class="row">
<div app-sidebarfilter class="col-xs-3">sidebar</div>
<div class="col-xs-9">Content</div>
</div>
</div>
</div>
<app-footer></app-footer>
</div>






share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 21 at 11:37









ppollono

2,43311526




2,43311526












  • so you're suggesting changing the component selector to an attribute? That doesn't solve the problem, of wanting to put the col class inside the *.component.html. Strange the requirement for the col class to be immediately after the row class seems to be an issue with bootstrap 4, that wasn't present in 3
    – WindDude
    Nov 21 at 18:32




















  • so you're suggesting changing the component selector to an attribute? That doesn't solve the problem, of wanting to put the col class inside the *.component.html. Strange the requirement for the col class to be immediately after the row class seems to be an issue with bootstrap 4, that wasn't present in 3
    – WindDude
    Nov 21 at 18:32


















so you're suggesting changing the component selector to an attribute? That doesn't solve the problem, of wanting to put the col class inside the *.component.html. Strange the requirement for the col class to be immediately after the row class seems to be an issue with bootstrap 4, that wasn't present in 3
– WindDude
Nov 21 at 18:32






so you're suggesting changing the component selector to an attribute? That doesn't solve the problem, of wanting to put the col class inside the *.component.html. Strange the requirement for the col class to be immediately after the row class seems to be an issue with bootstrap 4, that wasn't present in 3
– WindDude
Nov 21 at 18:32




















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.





Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


Please pay close attention to the following guidance:


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53398775%2fbootstrap-4-cols-not-working-in-angular-component%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Wiesbaden

Marschland

Dieringhausen