I’m working on a little parsing thing to color objects.
For an example, you could type red:Hi!: and “Hi!” would be red.
This is my not working code:
<script type="text/javascript">
function post()
{
var preview = document.getElementById("preview");
var submit = document.getElementById("post");
var text = submit.value;
<?php str_replace("red:*:",'<i class="red">*</i>',text); ?>
preview.value = text;
}
</script>
You have at least two massive problems here.
You can’t str_replace with wildcards like you are (the asterisks you use are just that – the asterisk character, not a placeholder).
Your idea of the page-rendering process is off – you can’t just call some PHP code in JavaScript and have it update the page. Any PHP code will be executed and printed when your page is generated on the server – it can’t interact with the page like JavaScript can (JS can because it is executed within the browser, but the browser never actually sees your PHP code as you can check by going to View->Source and seeing what you see). You certainly cannot reference a JavaScript variable from PHP.
Two options.
Option 1 – Proper Server-Side
if you want to colour objects on page load based on post, do something like this:
Option 2 – Proper Client-Side
Include jQuery in your <head> tag to make your life easier. If you really don’t want to include jQuery you can still change the jQuery calls to your getElementById etc. (you’ll want to replace the html() call with ‘.innerhtml’ I think – just look it up).