Hacker News new | ask | show | jobs
by travisjungroth 2638 days ago
> I finished my first semester teaching at the University of Michigan. I taught EECS 493 User Interface Development all on the Web. It was a tough class for me since I had never before this class used JavaScript, jQuery, or CSS. I learned a lot, but I also had to teach it.

> I could not live code in this class. I didn’t know the material well enough. It took me too long to code, and I couldn’t recover from mistakes in front of the class.

Does it bother anyone else that the author was teaching something they weren't proficient in? Is this normal for colleges?

8 comments

Yes, this bothers me greatly, particularly since in 2018-19 you could throw a pebble in any direction and hit someone who knows JS/jQuery/CSS/HTML. You almost have to go out of your way to find someone who doesn’t. I’m sure this guy is great at other things but students are paying thousands of dollars for this education.

I only remember having one prof who clearly didn’t know the material. He spent most of every class just copying code onto the board by hand, then trying to talk about it a bit. I really didn’t learn much in that class. Unfortunately it was the foundational C++ class at my university and really kind of handicapped me in successive classes that were also taught in C++.

My alma mater? The University of Michigan.

> in 2018-19 you could throw a pebble in any direction and hit someone who knows JS/jQuery/CSS/HTML.

You could, but they all have jobs doing actual programming. Universities pay sub-poverty wages to adjuncts to teach most of their classes and so this is what they get. It sounds like this person at least cares and is working hard to teach the material.

>Does it bother anyone else that the author was teaching something they weren't proficient in? Is this normal for colleges?

Yes, it concerns me - but it doesn't really surprise me (my own UG CS experiences have really disillusioned me with regard to how much of a priority teaching quality really is, particularly in research-intensive institutions). It doesn't sound like the author had much say in the situation "I also had to teach it", so unsure if the department is the root problem here.

But it's doing a disservice to students - particularly given in the US they'll be paying much, much more than the tuition fees here in the UK (which I think are excessive as it is). It's not good enough. If you're going to offer a class that's more practical, covering real web technologies, do it properly or don't offer it at all. We risk teaching poor practices otherwise and I've seen these lead to real security issues when students enter industry and want to put these skills to use.

I'm from a country where it's not too rare to see teachers in their 60s, who pretty much taken deep roots in the university, reading lectures in monotone without ever touching practice on the subject in the ‘real world.’ The lag of universities behind modern technology has become a matter of frustrated laughter here, and a widespread position is that a degree is only for the resume, with you forgetting everything you ‘learned’ on the day you graduate.

And my belief, as far as I gathered from hearsay, was that ‘Western’ approach was different, what with having professors who actually work in the field between lectures. So I was, uh, rather surprised to read this.

It bothers me that jQuery is in the mix. That has to be unlearned, it is a layer of abstraction that really is not needed. A decade ago jQuery was great but I am increasingly finding Stack Overflow answers of the 'in jQuery...' type being answered with a polite 'yes but no thanks, I want to do it in javascript'.

What does bother me is the lack of education regarding the HTML elements. How often have I seen anyone with a MDN page reference for an element? That never happens! Yet it is the dictionary and there aren't a lot of elements to remember unless you are trying to draw SVG shapes with masks, arrow heads on them and fancy fills.

Is there a good place to get a good idea of what is being taught to students these days? I am sure that the basic HTML elements are being skipped over and I would not mind confirming that.

In this case, he should have recruited students who are well versed in these things to help conducting the course as TAs. He could have only taught about the principal/design, and let the TAs teach the real coding part.

I found this approach is very effective for students because they basically learn the skills from their peers or even roommates, and if they are friends on campus, they can ask questions any time outside of TA hours. My alma mater has an excellent undergrad TA program where students who performed well in the course are recruited to be TAs when the course is offered later again.

This does happen most of the time, and UM has quite a large TA group. He almost definitely had TAs and the majority of the learning is around discussion/recitation sections and practice. In this case, he also wasn't developing the course from scratch either. So, the content in the course was built by those more familiar with the web.
The major crisis in university CS Ed is that there are nowhere NEAR enough qualified professors to teach all the subjects. There will not be enough in the next 5 years, assuming there is no radical change in qualification expectations. There are simply not enough PhDs being granted to keep up with the demand of students, and not enough students want to stick around and teach when they could be making tons of money in industry instead.

Universities have a short list of options. Having instructors who are smart and understand the material but may not be masters of it? That's a really good situation to be in, compared to the worst case scenarios. Sure, maybe Mark doesn't feel comfortable live coding in front of a classroom for web dev (a skill, by the way, that changes dramatically every year). But he's someone who cares about teaching, plays around with his teaching strategy, and is smart (I mean, he's freaking Mark Guzdial). With those three facts, his students are in a significantly better situation than the average university class.

I had to teach "Intro to Algorithms" the past two semesters. I got an A in that class when I took it, and I'm able to solve most problems from the textbook. Does that mean I can stand up in front of the class and solve any question from the textbook? Absolutely not. Does that make me less qualified than Skienna or Djikstra? Absolutely. Does that mean I can't teach the class? I don't think it does. I can build and grade assignments, I can lecture in class, I can answer most reasonable questions that students have, and I can build good exams that fairly measure my students' knowledge. I'm sure my students would prefer to have an instructor who can do all of those things and also be able to perfectly answer any possible Algorithms question they may have. But unfortunately, that person doesn't exist at University of Delaware - or if they do, then they're teaching one of the other required courses, and we couldn't spare them to teach Intro to Algorithms. It's just the way things are with hiring. I don't think my students' careers are going to suffer because I can't whip out a proof for the reduceability of Vertex Cover to 3-Sat live in front of them.

Ironically, I would feel extremely confident about live coding for a Web Dev course. Hopefully I get a chance to teach one at some point, because I'm pretty sick of teaching Intro to Algorithms :)

> and not enough students want to stick around and teach when they could be making tons of money in industry instead.

Especially not since there typically isn't a good university career path for teachers. Research is generally valued a lot more when it comes to getting a permanent position etc.

It's true, but that will have to change if they want to start handling the volume of students we're being asked to handle.
In this case we can probably assume the author is proficient in several other languages, as well as in pedagogy, so nah.
I'm sure it bothered him, too. Keep in mind that the goals of university courses are not just to learn the material but to learn how to learn something. I know it bothers faculty members when they barely feel ahead, but at the same time -- teaching well is as much about understanding pedagogy as it is about understanding the content. And there's a lot of computer-science specific teaching techniques that would transfer to this course.

In an intro course, you seldom get into the super advanced parts of that topic. He's still a very distinguished CS instructor, and even if a student were to ask some question about, say, a CSS cascade question, he'd be more than capable of looking up the answer and explaining things, even if he doesn't know something on the spot.

I'll add that when live coding, you need to generally be more than just comfortable explaining a topic -- even if you understand say, using jQuery callbacks with AJAX requests, you'd probably avoid teaching it live until you know how to recover from errors in reasonable ways or exactly where in the docs you need to look. It's not that you couldn't figure out the solution, but you want to be comfortable debugging something on the order of seconds of to a minute or two so you don't loose lecture time.